在c#中将gridview导出为ex​​cel

时间:2012-11-08 12:27:48

标签: c# excel gridview export

我必须将gridview导出为ex​​cel。我在按钮单击事件功能中使用以下代码:

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”等,但没有结果。代码中的错误是什么,以及字符串文件未填充的原因可能是什么?

提前致谢

1 个答案:

答案 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.  
}

请参阅herehere