我必须将gridview导出为excel。我在按钮单击事件功能中使用以下代码:
Response.Clear();
Response.Buffer = true;
Response.AddHeader("Content-Disposition","attachment;filename=sample.xls");
Response.Charset = "";
Response.ContentType = "app`enter code here`lication/vnd.xls";
StringWriter stringWriter = new StringWriter();
HtmlTextWriter htw = new HtmlTextWriter(stringWriter);
grdVw.RenderControl(htw);
Response.Write(stringWriter.ToString());
Response.End();
当我运行这个时,会打开一个对话框,显示下载一个空的XML文件。当我尝试调试它时,我发现网格有数据,但是stringWriter没有填充。我试图将内容类型更改为“application / ms-excel”等,但没有结果。代码中的错误是什么,以及字符串文件未填充的原因可能是什么?
提前致谢
答案 0 :(得分:0)
我假设grdVw.RenderControl(htw);
引发了一个异常,即GridView没有以服务器形式呈现。
尝试在调试器中执行它,我很确定你会看到异常。
您可以通过覆盖VerifyRenderingInServerForm
来避免此异常public override void VerifyRenderingInServerForm(Control control)
{
// Confirms that an HtmlForm control is rendered for the specified ASP.NET
// server control at run time.
}