对不起我的英语不好。我使用了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

07-24 09:38