2013-04-05 71 views
1

我正在导出到MVC4应用程序中的excel文件。
Excel中导出到Excel - 在MVC4中安装Office自定义

public class ExporttoExcel : ActionResult 
{ 
public GridView ExcelGridView { get; set; } 
public string fileName { get; set; } 
public int totalQuantity; 
public decimal totalPrice1; 
public string x1; 

public ExporttoExcel(GridView gv, string pFileName, int totalQty, decimal totalPrice, string x) 
{ 
    x1= x; 
    ExcelGridView = gv; 
    fileName = pFileName; 
    totalQuantity = totalQty; 
    totalPrice1 = totalPrice; 
} 
    public override void ExecuteResult(ControllerContext context) 
    { 
    HttpContext curContext = HttpContext.Current; 
    curContext.Response.Clear(); 
    curContext.Response.AddHeader("content-disposition", "attachment;filename=" + fileName); 
    curContext.Response.Charset = ""; 
    curContext.Response.Cache.SetCacheability(HttpCacheability.NoCache); 
    curContext.Response.ContentType = "application/vnd.ms-excel";  
    StringWriter sw = new StringWriter(); 
    HtmlTextWriter htw = new HtmlTextWriter(sw); 
    if (x1== "111") 
    { 
     htw.WriteLine("<html><head>"); 
     //code logic 
     ExcelGridView.HeaderStyle.BackColor = Color.Yellow; 
     ExcelGridView.RenderControl(htw); 
     htw.WriteLine("</body></html>"); 
    } 
    else 
    { 
     htw.WriteLine("Data"); 
     ExcelGridView.RenderControl(htw); 
    } 
    byte[] byteArray = Encoding.ASCII.GetBytes(sw.ToString()); 
    MemoryStream s = new MemoryStream(byteArray); 
    StreamReader sr = new StreamReader(s, Encoding.ASCII); 
    curContext.Response.Write(sr.ReadToEnd()); 
    curContext.Response.End(); 
    } 
} 

出现下面的错误和Excel不打开文件。

Error : 
From: file:///d:/Program Files/Microsoft Visual Studio 10.0/Common7/IDE/PrivateAssemblies/Microsoft.VisualStudio.QualityTools.LoadTestExcelAddIn.vsto did not succeed. 


在我的代码中的任何错误。我该怎么做才能解决这个错误。 ?
编辑:
此错误仅在IE中出现。 Firefox和Chrome打开excel文件。

+0

Excel旨在打开Excel文件。你在这里做的是一个HTML文件。 – 2013-04-05 05:58:46

+0

为什么你不直接发送内容到响应?你需要中间文件吗? “if”的哪个分支正在执行? – 2013-04-05 06:07:31

+0

@Darin是的。我传递一个gridview.It是主要的东西,必须出口到excel .. html只用于装饰excel。 – kk1076 2013-04-05 06:39:55

回答

0

我在我的本地机器中指定错误的位置添加了三个文件。

Microsoft.VisualStudio.QualityTools.LoadTestExcelAddIn.dll 
Microsoft.VisualStudio.QualityTools.LoadTestExcelAddIn.dll.manifest 
Microsoft.VisualStudio.QualityTools.LoadTestExcelAddIn 

工作正常,IE打开Excel文件。