保存/创建/导出Excel工作表时出现C#-OutOfMemoryException
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了保存/创建/导出Excel工作表时出现C#-OutOfMemoryException,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2075字,纯文字阅读大概需要3分钟。
内容图文
开发环境:
>操作系统-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万行.我使用伪造数据对其进行了测试,因此可能需要进行一些小的更改/修复.
内容总结
以上是互联网集市为您收集整理的保存/创建/导出Excel工作表时出现C#-OutOfMemoryException全部内容,希望文章能够帮你解决保存/创建/导出Excel工作表时出现C#-OutOfMemoryException所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。