尝试将数据表从内存流写入输出流时的网页在尝试将excel文件传递给用户时抛出System.OutOfMemoryException。我使用Closed XML在Excel中保存文件,数据表大约有40K行和150列大,主要包含小数,导出的文件通常是10MB或更大。在导出到excel时,有哪些建议的技巧可以解决大数据集?
这是我正在使用的封闭式XML代码http://closedxml.codeplex.com/wikipage?title=How%20do%20I%20deliver%20an%20Excel%20file%20in%20ASP.NET%3f&referringTitle=Documentation
public HttpResponseMessage Get()
{
// Create the workbook
var workbook = new XLWorkbook();
Datatable dt = getDataTable();
workbook.Worksheets.Add(dt);
// Prepare the response
HttpResponseMessage response = new HttpResponseMessage(HttpStatusCode.OK);
var memoryStream = new MemoryStream(); // If I put this in a 'using' construct, I never get the response back in a browser.
workbook.SaveAs(memoryStream);
memoryStream.Seek(0, SeekOrigin.Begin); // Seem to have to manually rewind stream before applying it to the content.
response.Content = new StreamContent(memoryStream);
response.Content.Headers.ContentType = new MediaTypeHeaderValue("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
response.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment") { FileName = "HelloWorld.xlsx" };
return response;
}
答案 0 :(得分:4)
我偶然发现了这个链接OpenXML libraries (alternatives to ClosedXML)当大量数据导出到Excel时,EPPlus https://epplus.codeplex.com/比ClosedXML好得多。 至少没有“OutOfMemory”例外,因为EPPlus似乎避开了Memory Streams,尽管我仍然有兴趣了解他们是如何实现这一点的,甚至是了解Closed XML和EPPlus之间的区别。
答案 1 :(得分:3)
您可以通过以下类型来避免内存溢出异常。
代码段[C#]:
ExcelEngine excelEngine = new ExcelEngine();
IApplication application = excelEngine.Excel;
IWorkbook workbook = application.Workbooks.Create(1); //We are using single workbook
IWorksheet sheet = workbook.Worksheets[0]; //In this case we are exporting to single ExcelSheet so we marked Worksheets as 0
for (int i = 0; i < grid.Model.RowCount; i++)
{
//Setting Excel cell height based on Grid Cell height
sheet.SetRowHeightInPixels(i + 1, set heigth here);
for (int j = 0; j < ColumnCount; j++)
{
int width = Convert.ToInt32(ColumnWidths[j]); //Getting Grid Cell column width
sheet.SetColumnWidthInPixels(j + 1, width); //Setting Width for Excel cell
sheet.Range[i + 1, j + 1].Text = dt value here;
}
}