asp.net - 如何将大数据导出到Excel

标签 asp.net excel large-files export-to-excel

我的 asp.net 应用程序中有一个条件页面。当用户单击报告按钮时,首先在新页面中将结果绑定(bind)到数据网格,然后使用更改内容类型方法将该页面导出到 Excel 文件。

正常情况下是可以的,但是当大量数据到来时,就会抛出system.outofmemoryException。

有人知道解决这个问题的方法,或者其他有用的技术吗?

最佳答案

发生这种情况的原因可能是您的应用程序正在尝试在内存中构建整个 Excel 电子表格,然后在完成后将其交付给用户。对于大型数据集,您可以轻松用完所有可用内存,这很可能还会导致其他用户的应用程序速度显着减慢。

相反,您可以尝试将数据流式传输给用户。无论数据集有多大,这都将使用相同的内存量。您可以获取 Excel 电子表格的字节,或者只需将数据转换为 CSV,然后设置 HTTP 响应类型并将其流式传输给用户。

这是一个例子:

byte[] reportDoc = GetExportExcel();
context.Response.ContentType = "application/vnd.ms-excel";

//set the content disposition header to force download
context.Response.AddHeader("Content-Disposition", "attachment;filename=" +
                    "Export.xls");

//write the file content byte array
context.Response.BinaryWrite(reportDoc);

详细教程http://bytes.com/topic/asp-net/answers/326796-example-streaming-excel-browser-download

关于asp.net - 如何将大数据导出到Excel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3039880/

相关文章:

java - 大型电子表格的 Apache POI Java Excel 性能

vba - 使用 VBA 将两个不同工作表上的多个范围保存为 PDF

asp.net - Web配置和机器配置

asp.net - 工作线程和 I/O 线程有什么区别?

excel - 比较 2 个单元格之间的值,其中一个单元格具有自定义数字格式

c# - 巨大的 XML 文件的问题

c++ - std::ostream::write 有什么限制吗?

java - 在 Java 中打开一个大文件非常慢

c# - 登录用户名和文本框文本未保存在数据库中

javascript - href ="javascript:..."语法突然在 FireFox 的 FB Iframe 中不起作用