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