当前位置: 首页 > news >正文

记录C#导出数据慢的优化方法

Winform程序将数据库中的历史数据导出到Excel中速度慢,导出1000多条数据优化前需要40秒,优化后只需要2秒,4万条数据只需要10秒。

优化前:

for (int i = 0; i < myDGV.Columns.Count; i++)
{worksheet.Cells[1, i + 1] = myDGV.Columns[i].ColumnName;
}
//写入数值
for (int r = 0; r < myDGV.Rows.Count; r++)
{for (int i = 0; i < myDGV.Columns.Count; i++){worksheet.Cells[r + 2, i + 1] = myDGV.Rows[r][i].ToString();}System.Windows.Forms.Application.DoEvents();
}

优化后:

int rowCount = myDGV.Rows.Count;
int columnsCount = myDGV.Columns.Count;
string lastRange = ConvertToTitle(columnsCount) + (rowCount + 1);
object[,] datas = worksheet.Range["A1", lastRange].Value2;
for (int i = 0; i < columnsCount; i++)
{datas[1, i + 1] = myDGV.Columns[i].ColumnName;
}
//写入数值
for (int r = 0; r < rowCount; r++)
{for (int i = 0; i < columnsCount; i++){datas[r + 2, i + 1] = myDGV.Rows[r][i].ToString();}System.Windows.Forms.Application.DoEvents();
}
worksheet.Range["A1", lastRange].Value2 = datas;

优化思路:
优化前是在for循环中,不断的操作真实的worksheet表格文件,向其中添加数据,这一步操作存在耗时,再根据数据量大小循环几千几万次后累计耗时就很大了;优化后是先创建一个表格数据对象,向数据对象中循环添加数据,数据全部添加完后,再向真实的worksheet中一次性写入数据后保存。

http://www.lryc.cn/news/303357.html

相关文章:

  • Android批量加载图片OOM问题
  • SNAT与DNAT公私网地址转换
  • 快速上手Spring Boot整合,开发出优雅可靠的Web应用!
  • MySQL高级特性篇(7)-数据库版本控制与迁移
  • js判断对象是否为空
  • 2024前端面试准备之HTML篇
  • devOps系列(八)efk+prometheus+grafana日志监控和告警
  • 考研英语单词29
  • spring-security 过滤器
  • 掌握这7种软件设计原则,让你的代码更优雅
  • Flutter自定义tabbar任意样式
  • Java设计模式【策略模式】
  • (13)Hive调优——动态分区导致的小文件问题
  • 【linux】使用g++调试内存泄露:AddressSanitizer
  • 第三百五十七回
  • 新版Java面试专题视频教程——框架篇
  • 网络爬虫实战 | 上传以及下载处理后的文件
  • Linux--shell编程中有关while循环的详细内容
  • 回归测试与重新测试
  • java 版本企业招标投标管理系统源码+多个行业+tbms+及时准确+全程电子化
  • 详解动态内存管理!
  • iocp简单例子
  • HAL STM32 HW I2C DMA + SSD1306/SH1106驱动示例
  • grafana配置钉钉告警模版(一)
  • 佳能2580的下载手册
  • YOLO-World:实时开放词汇目标检测
  • Unity中关于群组的一些组件
  • 面向对象详解,面向对象的三大特征:封装、继承、多态
  • 【阿里云服务器的一些使用坑】都是无知的泪水呀
  • Docker的常用命令||Docker是个流行的容器化平台,它允许你打包、分发和运行应用程序。