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