如何将大数据导出到Excel

mav*_*era 2 asp.net excel export-to-excel large-files

我的asp.net应用程序中有一个标准页面.当用户单击报告按钮时,首先在新页面中将结果绑定到数据网格,然后将此页面导出为具有更改内容类型方法的excel文件.

这通常有效,但是当大量数据到来时,会抛出system.outofmemoryexception.

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

Nat*_*dek 6

这可能是因为您的应用程序正在尝试在内存中构建整个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);
Run Code Online (Sandbox Code Playgroud)

有一个详细的教程,请访问http://bytes.com/topic/asp-net/answers/326796-example-streaming-excel-browser-download