用Stopwatch分段監控了一下,發現耗時最多的函數是SaveToExcel
此函數中遍列所有數據行,通過Replace替換標簽生成Excel行,然後將行數據累加賦值到一個字符串
復制代碼 代碼如下:
string excelString = "";
foreach(var item in list){
excelString += string.Format("<row>....{0}</row>",list.Title);
}
看到這。。立馬想起無數先烈們的警告、字符串拼接的內存操作原理等等。於是大手一揮,代碼全刪,改為如下形式
復制代碼 代碼如下:
string excelString = new StringBuilder();
foreach(var item in list){
excelString.AppendFormat("<row>......{0}</row>",list.Title);
}
再次測試,效率立馬提升了幾十倍。之前8000行需要30s,現在只需要2s