标签:export-to-excel out-of-memory excel-interop c excel
开发环境:
>操作系统-Windows 7 64位
> CPU-i5 460M
>内存-8GB
> .NET Framework-4.0
> Excel-Interop-Microsoft Excel 14.0对象库
我正在使用Excel-Interop从DataGridView(dgv)导出Excel文件.
当我保存超过150,000行时
OutOfMemoryException
被抛出.
{
object[,] valueObjArray = new object[rowCnt, colCnt];
int rowCnt = dgv.Rows.Count;
int colCnt = dgv.Columns.Count;
for (int rowIndex = 0; rowIndex < rowCnt; rowIndex++)
{
for (int colIndex = 0; colIndex < colCnt; colIndex++)
{
valueObjArray[rowIndex, colIndex] = dgv[colIndex, rowIndex].Value;
}
}
_workSheet.get_Range("A1", Convert.ToChar(colCnt + 64).ToString() + "1").Value2 = headerObjArray;
_workSheet.get_Range("A2", Convert.ToChar(colCnt + 64).ToString() + (rowCnt + 1).ToString()).Value2 = valueObjArray;
_workSheet.get_Range("B2", "B" + (rowCnt+1).ToString()).NumberFormat = "yyyy-mm-dd hh:mm";
_workBook.SaveAs(path);
}
这是我所知加快速度的最佳方法.
但是,在监视RAM之后,我认为这会导致内存增加.当内存使用量达到约900Mb时,将引发异常.
如何捕获此异常?
解决方法:
尝试分批执行:
//We will call SaveAs method many times and we don't want to be asked
//if a file should be overwritten every time.
xlApp.DisplayAlerts = false
int rowCnt = dgv.Rows.Count;
int colCnt = dgv.Columns.Count;
int batchSize = 100000; //Try to experiment with other values
int currentRow = 0;
object[,] valueObjArray = new object[batchSize, colCnt];
_workSheet.get_Range("A1", Convert.ToChar(colCnt + 64).ToString() + "1").Value2 = headerObjArray;
while (currentRow < rowCnt)
{
for (int rowIndex = 0; rowIndex < batchSize && currentRow + rowIndex < rowCnt; rowIndex++)
{
for (int colIndex = 0; colIndex < colCnt; colIndex++)
{
valueObjArray[rowIndex, colIndex] =
dgv[colIndex, currentRow + rowIndex].Value;
}
}
ws.get_Range("A2", Convert.ToChar(colCnt + 64).ToString() + (currentRow + batchSize + 1).ToString()).Value2 = valueObjArray;
ws.get_Range("B2", "B" + (currentRow + batchSize + 1).ToString()).NumberFormat = "yyyy-mm-dd hh:mm";
wb.SaveAs("a.xlsx");
currentRow += batchSize;
}
这样我就可以保存100万行.我使用伪造数据对其进行了测试,因此可能需要进行一些小的更改/修复.
标签:export-to-excel,out-of-memory,excel-interop,c,excel 来源: https://codeday.me/bug/20191119/2032539.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。