Winform中導出Excel數據量百萬級的處理辦法-導出爲csv文件

場景

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

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

在上面介紹的第三種方式中通過SXSSFWorkbook就是應對數據量特別大的情況下,

但是SXSSFWorkbook的方式雖然對內存佔用較小,不對導致內存溢出,但是其導出的時間會特別長。

而且還會在你的C盤目錄下生成一些臨時文件,佔用你的C盤空間。

具體實現方式參照上面的博客。

但是比較好的方面就是它導出的是正常的xlsx的後綴的excel文件,即能包含多個sheet頁。

如果要是對多sheet頁沒有要求,可將大數據量分批次生成csv文件的格式,每個csv文件100萬條記錄

注:

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

實現

首先新建一個Winform程序,然後新建一個頁面,並且拖拽一個按鈕。

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

    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.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);

                //構建大數據量
                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);

                }

                //新建一個計時器
                System.Diagnostics.Stopwatch timer = new System.Diagnostics.Stopwatch();
                //啓動計時器
                timer.Start();

                //寫出各行數據
                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();
                //結束計時
                timer.Stop();
                MessageBox.Show("導出成功,花費秒數:"+(timer.ElapsedMilliseconds)/1000);
            }
            catch (Exception ex)
            {
                Console.Write(ex);
                MessageBox.Show("導出失敗:"+ex);
            }
           
        }

爲了增加測試導出大數據量的時間,所以首先構建了一個1000000萬條記錄,然後循環一行一行的追加,

添加一個計時,看看花費了多少時間

 

此文件的後綴名爲csv可以使用Excel打開

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章