对不起我的英语不好。我使用了Epplus库,我非常喜欢它。但是我有一个问题:内存不足。无论如何,都需要写入大量数据。我想知道是否有可能追加到Excel文件的末尾而不是全部存储在内存中。或创建多个文件,然后串联成一个文件。提前致谢。
最佳答案
1)如果您从数据库中检索数据
使用数据读取器而不是数据表
2)将excel写入临时文件,完成后将其删除(如果是网络环境,请使用response.writefile然后将其删除)
3)先写头,然后将数据附加到头
这样的事情(用我的手机输入)
var pck = new ExcelPackage();
var ws = pck.AddSheet("sheet1");
//write header here
pck.saveas(fileinfo);
pck.dispose(); // not sure if function existed
pck= new excelpage(fileino.fullname);
ws = pck.worksheets[1];
var rowIndex =0;
while (reader.read())
{
if (++rowindex % 100000 == 0)
{
// save and re-open
}
//write row here
}
pck.save();
//dispose / send file / delete file etc