日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > C# >内容正文

C#

C#中导出百万级Excel只需几秒除了NPOI还可以这样

發布時間:2025/3/19 C# 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C#中导出百万级Excel只需几秒除了NPOI还可以这样 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

場景

Winform中通過NPOI導出Excel的三種方式(HSSFWorkbook,XSSFWorkbook,SXSSFWorkbook)附代碼下載:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/106423452

之前在使用NPOI進行導出Excel時遇到百萬級別的可以采用SXSSFWorkbook的方式。

但是速度還是很慢。但是有點是導出的是嚴格意義上的Excel,即可以設置正常的多sheet頁以及能設置每個Cell的格式等。

但是如果數據量很大只求能導出數據作為備份,不對格式等有嚴格的要求,可以采用文件流的方式快速導出。

注:

博客主頁:
https://blog.csdn.net/badao_liumang_qizhi
關注公眾號
霸道的程序猿
獲取編程相關電子書、教程推送與免費下載

實現

為了能構建導出的數據,首先新建一個對象類

??? 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; }}


然后進入此頁面的代碼中,先構建一部分導出的數據。

??????? //數據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 = "氣質",Age = 26,Address = "上海",Sex = 0,Birth = DateTime.Now},new DataItem() {Name = "程序猿",Age = 27,Address = "青島",Sex = 1,Birth = DateTime.Now},};


然后在按鈕的點擊事件中

private void button6_Click(object sender, EventArgs e){try{//要導出的csv文件的存放位置string fullPath = System.IO.Path.Combine(@"D:\", "badao.xls");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);//構建大數據量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);}//寫出各行數據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);}//關閉sw.Close();fs.Close();MessageBox.Show("導出成功");}catch (Exception ex){Console.Write(ex);MessageBox.Show("導出失敗:"+ex);}}

但是這樣導出的數據在使用Excel打開時會有提示,點擊是就能打開

?

點擊是后正常打開

?

總結

以上是生活随笔為你收集整理的C#中导出百万级Excel只需几秒除了NPOI还可以这样的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。