.net core 基於NPOI 的excel導出類,支持自定義導出哪些欄位

来源:http://www.cnblogs.com/hzzxq/archive/2017/09/16/7531790.html
-Advertisement-
Play Games

/// /// 導出Excel /// /// /// 英文中文列名對照 /// 保存路徑 public static void getExcel(List lists, Dictionary head, string workbookFile) { ... ...


/// <summary>  
        /// 導出Excel  
        /// </summary>  
        /// <param name="lists"></param>  
        /// <param name="head">英文中文列名對照</param>  
        /// <param name="workbookFile">保存路徑</param>  
        public static void getExcel<T>(List<T> lists, Dictionary<string,string> head, string workbookFile)
        {
            try
            {

                XSSFWorkbook workbook = new XSSFWorkbook();
                using (MemoryStream ms = new MemoryStream())
                {
                    var sheet = workbook.CreateSheet();
                    var headerRow = sheet.CreateRow(0);
                    bool h = false;
                    int j = 1;
                    Type type = typeof(T);
                    PropertyInfo[] properties = type.GetProperties();
                    foreach (T item in lists)
                    {
                        var dataRow = sheet.CreateRow(j);
                        int i = 0;
                        foreach (PropertyInfo column in properties)
                        {
                            if (!h)
                            {
                                if (head.Keys.Contains(column.Name))
                                {
                                    headerRow.CreateCell(i).SetCellValue(head[column.Name] == null ? column.Name : head[column.Name].ToString());
                                    dataRow.CreateCell(i).SetCellValue(column.GetValue(item, null) == null ? "" : column.GetValue(item, null).ToString());

                                }
                                else
                                {
                                    i -= 1;
                                }

                            }
                            else
                            {
                                if (head.Keys.Contains(column.Name))
                                {
                                    dataRow.CreateCell(i).SetCellValue(column.GetValue(item, null) == null ? "" : column.GetValue(item, null).ToString());
                                }
                                else
                                {
                                    i -= 1;
                                }

                            }
                            i++;
                        }
                        h = true;
                        j++;
                    }
                   
                    workbook.Write(ms);
                    using (FileStream fs = new FileStream(workbookFile, FileMode.Create, FileAccess.Write))
                    {
                        byte[] data = ms.ToArray();
                        fs.Write(data, 0, data.Length);
                        fs.Flush();
                    }
                    sheet = null;
                    headerRow = null;
                    workbook = null;
                }
            }
            catch (Exception ee)
            {
                string see = ee.Message;
            }
        }

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、安裝環境 硬體:虛擬機 操作系統:Centos 7.0 64位 IP:192.168.120.150 hadoop-2.7.0.tar.gz 鏈接:http://pan.baidu.com/s/1eRT0tk2 密碼:ymim jdk-8u45-linux-x64.tar.gz 鏈接:http: ...
  • 經常使用的命令: #查看埠被占用情況 netstat -tunlp|grep 22 #查看java進程 ps -ef|grep java #壓縮前端工程 rar a -ep1 ./update/win32.zip ./packages/**/win32/* #查找所有帶wine的文件和文件夾 fi ...
  • MySQL資料庫增量備份,在這之前修改我們的資料庫配置文件/etc/my.cnf開啟bin-log日誌功能即可。接下來是我參考了下網上的一些方法,自己寫的,主要還是要能學到他的一些思路和方法。 添加計劃任務: crontab -e 00 03 * * * /root/MySQL_incrementb ...
  • Linux必知必會的目錄,linux啟動過程,PATH環境變數作用 ...
  • 服務端環境:CentOS 6.7客戶端環境:Windows 7 1.伺服器安裝VNC服務端 可以直接rpm安裝vnc的服務端: 如果rpm安裝時發現有依賴,建議直接使用yum安裝,輕鬆解決依賴問題: 如果系統安裝時並沒有安裝桌面選項,那麼就還需要用yum安裝一下桌面: 2.編輯vnc配置文件 編輯/ ...
  • 本文目錄: 1.1 SysV腳本的特性1.2 SysV腳本要具備的能力1.3 start函數分析1.4 stop函數分析1.5 reload函數分析1.6 status、restart、force-reload等1.7 結束語 SysV服務管理腳本和/etc/rc.d/init.d/function ...
  • 第四天,繼續學習。今天看到一句話,"你以為你以為的就是你以為的嗎?",這句話還是有點意思啊!!! 一、查看文件內容的命令 file dest:查看文件的類型。在Linux中,文件的類型有文本文件、目錄、鏈接文件(硬鏈接和軟鏈接)、腳本文件(可執行文件)、二進位文件等等。 cat dest:查看文件的 ...
  • vim是一款文本編輯工具,因此學習時不求功能全記住,只要在使用vim時工作更有效率就可以了。本文從實用的角度總結了vim的操作方法,希望讀者讀完本文後經過練習都能達到飛一般的文本編輯速度。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...