我在我的asp.net应用程序中有一个标准页面。当用户点击报告按钮时,首先在一个新页面中将结果绑定到一个数据网格,然后通过改变内容类型方法将该网页导出到excel文件。如何将大数据导出到Excel
这通常有效,但是当大量数据到来时,会抛出system.outofmemoryexception。
有没有人知道一种方法来解决这个问题,或另一个有用的技术呢?
我在我的asp.net应用程序中有一个标准页面。当用户点击报告按钮时,首先在一个新页面中将结果绑定到一个数据网格,然后通过改变内容类型方法将该网页导出到excel文件。如何将大数据导出到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一个详细的教程
Excel中也有记录的最大数目,我相信是大约65K,虽然可能不是直接你的问题的结果,但如果你在与他们一起工作时遇到错误,可能仍会出现。
限制是每张表,并且只是旧的XLS文件类型的问题。 – Moulde 2013-01-04 11:15:21