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文件。
Excel旨在打开Excel文件。你在这里做的是一个HTML文件。 – 2013-04-05 05:58:46
为什么你不直接发送内容到响应?你需要中间文件吗? “if”的哪个分支正在执行? – 2013-04-05 06:07:31
@Darin是的。我传递一个gridview.It是主要的东西,必须出口到excel .. html只用于装饰excel。 – kk1076 2013-04-05 06:39:55