Winform中导出Excel数据量百万级的处理办法-导出为csv文件
場景
Winform中通過NPOI導(dǎo)出Excel的三種方式(HSSFWorkbook,XSSFWorkbook,SXSSFWorkbook)附代碼下載:
https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/106423452
在上面介紹的第三種方式中通過SXSSFWorkbook就是應(yīng)對數(shù)據(jù)量特別大的情況下,
但是SXSSFWorkbook的方式雖然對內(nèi)存占用較小,不對導(dǎo)致內(nèi)存溢出,但是其導(dǎo)出的時(shí)間會特別長。
而且還會在你的C盤目錄下生成一些臨時(shí)文件,占用你的C盤空間。
具體實(shí)現(xiàn)方式參照上面的博客。
但是比較好的方面就是它導(dǎo)出的是正常的xlsx的后綴的excel文件,即能包含多個(gè)sheet頁。
如果要是對多sheet頁沒有要求,可將大數(shù)據(jù)量分批次生成csv文件的格式,每個(gè)csv文件100萬條記錄
注:
博客主頁:
https://blog.csdn.net/badao_liumang_qizhi 
 關(guān)注公眾號
 霸道的程序猿
 獲取編程相關(guān)電子書、教程推送與免費(fèi)下載。
實(shí)現(xiàn)
首先新建一個(gè)Winform程序,然后新建一個(gè)頁面,并且拖拽一個(gè)按鈕。
為了能構(gòu)建導(dǎo)出的數(shù)據(jù),首先新建一個(gè)對象類
??? public class DataItem{public int Age { get; set; }public string Name { get; set; }public string Address { get; set; }public int Sex { get; set; }public DateTime Birth { get; set; }}然后進(jìn)入此頁面的代碼中,先構(gòu)建一部分導(dǎo)出的數(shù)據(jù)。
??????? //數(shù)據(jù)List<DataItem> ItemList = new List<DataItem>(){new DataItem() {Name = "霸道",Age = 24,Address = "中國",Sex = 1,Birth = DateTime.Now},new DataItem() {Name = "流氓",Age = 25,Address = "北京",Sex = 0,Birth = DateTime.Now},new DataItem() {Name = "氣質(zhì)",Age = 26,Address = "上海",Sex = 0,Birth = DateTime.Now},new DataItem() {Name = "程序猿",Age = 27,Address = "青島",Sex = 1,Birth = DateTime.Now},};然后在按鈕的點(diǎn)擊事件中
private void button6_Click(object sender, EventArgs e){try{//要導(dǎo)出的csv文件的存放位置string fullPath = System.IO.Path.Combine(@"D:\", "badao.csv");FileInfo fi = new FileInfo(fullPath);if (!fi.Directory.Exists){fi.Directory.Create();}FileStream fs = new FileStream(fullPath, System.IO.FileMode.Create, System.IO.FileAccess.Write);StreamWriter sw = new StreamWriter(fs, System.Text.Encoding.UTF8);StringBuilder data = new StringBuilder();//寫出列名稱-第一行data.Append("姓名,年齡,地址,性別,生日");//換行sw.WriteLine(data);//構(gòu)建大數(shù)據(jù)量List<DataItem> bigData = new List<DataItem>();for (int i = 0; i < 1000000; i++){DataItem item = new DataItem();item.Name = "霸道" + i;item.Age = i;item.Address = "青島" + i;item.Sex = i;item.Birth = DateTime.Now;bigData.Add(item);}//新建一個(gè)計(jì)時(shí)器System.Diagnostics.Stopwatch timer = new System.Diagnostics.Stopwatch();//啟動計(jì)時(shí)器timer.Start();//寫出各行數(shù)據(jù)foreach (DataItem item in bigData){data = new StringBuilder();data.Append(item.Name);data.Append(",");data.Append(item.Age);data.Append(",");data.Append(item.Address);data.Append(",");data.Append(item.Sex);data.Append(",");data.Append(item.Birth);data.Append(",");//換行sw.WriteLine(data);}//關(guān)閉sw.Close();fs.Close();//結(jié)束計(jì)時(shí)timer.Stop();MessageBox.Show("導(dǎo)出成功,花費(fèi)秒數(shù):"+(timer.ElapsedMilliseconds)/1000);}catch (Exception ex){Console.Write(ex);MessageBox.Show("導(dǎo)出失敗:"+ex);}}為了增加測試導(dǎo)出大數(shù)據(jù)量的時(shí)間,所以首先構(gòu)建了一個(gè)1000000萬條記錄,然后循環(huán)一行一行的追加,
添加一個(gè)計(jì)時(shí),看看花費(fèi)了多少時(shí)間
?
此文件的后綴名為csv可以使用Excel打開
?
總結(jié)
以上是生活随笔為你收集整理的Winform中导出Excel数据量百万级的处理办法-导出为csv文件的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: Winform中通过NPOI导出Exce
 - 下一篇: Electron中提示:Refused