记录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中一次性写入数据后保存。