asp.net gridview控件导出EXCEL 内存溢出

qgipfk168 2011-09-30 02:26:32
gridview 导出2W条记录,内存溢出,麻烦高手们给个解决方案。
 private void ExportCSV(string sql)
{
Response.Clear();
Response.Buffer = true;
Response.AddHeader("content-disposition", "attachment;filename=测试.xls");
Response.Charset = "";
Response.ContentType = "application/text";
GridView1.AllowPaging = false;
SqlDataSource1.SelectCommand = sql;
GridView1.DataBind();
StringBuilder sb = new StringBuilder();
for (int k = 0; k < GridView1.Columns.Count; k++)
{
//add separator
sb.Append(GridView1.Columns[k].HeaderText + ',');
}
//append new line
sb.Append("\r\n");
for (int i = 0; i < GridView1.Rows.Count; i++)
{
for (int k = 0; k < GridView1.Columns.Count; k++)
{
//add separator
sb.Append(GridView1.Rows[i].Cells[k].Text.Trim().Replace(" ", "") + ',');
}
//append new line
sb.Append("\r\n");
}
Response.Output.Write(sb.ToString());
Response.Flush();
Response.End();


}
...全文
208 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
qgipfk168 2011-10-08
  • 打赏
  • 举报
回复
有什么代码可以实现的吗? 不要去动服务器
xiangaylian 2011-09-30
  • 打赏
  • 举报
回复
是web站点么?
设置自动回收应用程序池试试。。
l576981437 2011-09-30
  • 打赏
  • 举报
回复
分成多个SHEET 试试
qgipfk168 2011-09-30
  • 打赏
  • 举报
回复
第三方的东西,服务器上最好不用,万一收费了,程序不是完了。看了一下,还是自动更新的,服务器压力大哇
tds__609 2011-09-30
  • 打赏
  • 举报
回复
建议使用NPOI,百度一下,你懂得
性能很好,速度很快~
fangyuantdy 2011-09-30
  • 打赏
  • 举报
回复
还是分批倒吧,数据量太大了

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧