基於.net EF6 MVC5+WEB Api 的Web系統框架總結(4)-Excel文件讀、寫操作

来源:https://www.cnblogs.com/henxiao25/archive/2019/09/21/11565500.html
-Advertisement-
Play Games

Excel文件讀、寫可以使用Office自帶的庫(Microsoft.Office.Interop.Excel),前提是本機須安裝office才能運行,且不同的office版本之間可能會有相容問題。還可以使用NPOI,在不安裝office的時候也是可以讀寫的,速度很快。當然,還有支持Excel200 ...


  Excel文件讀、寫可以使用Office自帶的庫(Microsoft.Office.Interop.Excel),前提是本機須安裝office才能運行,且不同的office版本之間可能會有相容問題。
還可以使用NPOI,在不安裝office的時候也是可以讀寫的,速度很快。當然,還有支持Excel2007以上版本的OpenXml。以及其他一些開源項目,由於本人不太熟悉,在此不做過多介紹。
  為瞭解決煩人Office版本相容問題,本項目-ShiQuan.Offices 決定採用基於NPOI,進行Excel文件讀、寫操作。
  本項目目前實現內容包括:
  1、直接根據DataTable,生成Excel文件內容。
  2、根據列表設置和DataTable,生成Excel文件內容。
  3、根據Excel模板,使用模板設置,生成Excel文件內容。
  4、讀取Excel內容,返回DataTable。

  本項目基於LGPL3.0開源,供大家參考、使用,歡迎提供寶貴意見!
  項目源碼:https://gitee.com/ShiQuanSoft/ShiQuan.Offices

 

  下麵介紹分享如何使用該項目-ShiQuan.Offices。
  首先,創建ConsoleApp測試項目,添加程式包安裝:

     

    1、先我們試下,普通的DataTable生成Excel文件是怎樣的?

try
            {
                //取出數據源
                DataTable dtData = new DataTable();
                dtData.Columns.Add("account");
                dtData.Columns.Add("realname");
                dtData.Columns.Add("birthday");
                dtData.Columns.Add("description");
                dtData.Columns.Add("remark");

                DataRow dr = dtData.NewRow();
                dr["account"] = "賬戶";
                dr["realname"] = "姓名";
                dr["birthday"] = "2000-05-25";
                dr["description"] = "說明";
                dr["remark"] = "說明";/*多餘欄位,不會數據導出*/
                dtData.Rows.Add(dr);
                Console.WriteLine("生成2007以上版本Excel...");
                NPOIHelper.SaveToExcel(dtData, "XSSFWorkbook.xlsx");
                Console.WriteLine("生成2003版本Excel...");
                NPOIHelper.SaveToExcel(dtData, "HSSFWorkbook.xls");
            }
            catch (Exception ex)
            {
                Console.WriteLine("導出異常:" + ex.Message);
            }

  運行效果:

     

  2、一般從系統中導出Excel,我們都將採用中文標題,設置相應的數據列格式,對齊方式等信息?

 

try
            {
                //取出數據源
                DataTable dtData = new DataTable();
                dtData.Columns.Add("account");
                dtData.Columns.Add("realname");
                dtData.Columns.Add("gender");
                dtData.Columns.Add("birthday");
                dtData.Columns.Add("enabled");
                dtData.Columns.Add("price");
                dtData.Columns.Add("percent");
                dtData.Columns.Add("money");
                dtData.Columns.Add("remark");

                DataRow dr = dtData.NewRow();
                dr["account"] = "賬戶";
                dr["realname"] = "姓名";
                dr["gender"] = "0";/*0:女*/
                dr["birthday"] = "2000-05-25";
                dr["price"] = "10.5656";
                dr["percent"] = "0.56";
                dr["money"] = "1000.56";
                dr["enabled"] = "1";/*是否啟用:1:是*/
                dr["remark"] = "說明";/*多餘欄位,不會數據導出*/
                dtData.Rows.Add(dr);
                /*設置導出格式*/
                ColumnCollection colModel = new ColumnCollection();
                colModel.Add("account", "賬戶");
                colModel.Add("realname", "姓名");
                colModel.Add("birthday", "出生日期", typeof(DateTime), "yyyy年MM月dd日");
                colModel.Add("price", "保留兩位",typeof(double), "#0.00");
                colModel.Add("percent", "百分比", typeof(double), "0.00%");
                colModel.Add(new ColumnModel() { Name = "money", Desc = "貨幣格式", Type = typeof(double), Format = "¥#,##0", TextAlign = ColumnAlign.Right });
                colModel.Add("gender", "性別", new DataOptions("0:女,1:男".Split(',')));
                colModel.Add(new ColumnModel[]
                {
                    new ColumnModel() { Name = "enabled", Desc = "是否啟用", Options = new DataOptions("0:否,1:是".Split(',')), TextAlign = ColumnAlign.Center }
                });

                Console.WriteLine("保存Excel...");
                //調用導出方法
                NPOIHelper.SaveToExcel(dtData,colModel, "用戶信息.xls");
                Console.WriteLine("Excel保存成功!");
            }
            catch (Exception ex)
            {
                Console.WriteLine("導出異常:" + ex.Message);
            }

 

  運行效果:

       

  3、當我們使用普通的設置數據列格式,還不能滿足要求時,此時,只能採用預定的Excel模板,使用數據填充方式,生成Excel文件?

var fileName = "根據模板生成Excel.xlsx";
            try
            {
                var templateFile = "templateFile.xlsx";
                System.IO.File.WriteAllBytes(templateFile, ConsoleApp.Properties.Resources.template);

                List<TemplateModel> list = new List<TemplateModel>();
                list.Add(new TemplateModel() { RowIndex = 1, ColIndex = 0, Value = "賬號" });
                list.Add(new TemplateModel() { RowIndex = 1, ColIndex = 1, Value = "名稱" });
                list.Add(new TemplateModel() { RowIndex = 1, ColIndex = 2, Value = "2000-09-01" });
                list.Add(new TemplateModel() { RowIndex = 1, ColIndex = 3, Value = "備註" });

                list.Add(new TemplateModel() { RowIndex = 2, ColIndex = 0, Value = "賬號" });
                list.Add(new TemplateModel() { RowIndex = 3, ColIndex = 1, Value = "名稱" });
                list.Add(new TemplateModel() { RowIndex = 4, ColIndex = 2, Value = "2000-09-01" });
                list.Add(new TemplateModel() { RowIndex = 5, ColIndex = 3, Value = "備註" });
                Console.WriteLine("根據模板生成Excel...");
                NPOIHelper.SaveToExcel(templateFile,"sheet1", list, fileName);
                Console.WriteLine("Excel保存成功!");
            }
            catch (Exception ex)
            {
                Console.WriteLine("生成異常:" + ex.Message);
            }

  定義的模板:

  

       運行效果:

  

  4、生成Excel文件方法介紹完畢,下麵我們看下怎麼讀取Excel文件內容,我們以直接讀取模板生成的Excel文件為例?

try
            {
                
                Console.WriteLine("讀取Excel內容...");
                DataTable dtData = NPOIHelper.ReadToTable(fileName);
                StringBuilder fileContent = new StringBuilder();
                //標題
                foreach (DataColumn dc in dtData.Columns)
                {
                    fileContent.Append(dc.ColumnName + "\t");
                }
                fileContent.AppendLine();

                foreach (DataRow dr in dtData.Rows)
                {
                    foreach (DataColumn dc in dtData.Columns)
                    {
                        if (dr[dc.ColumnName] == DBNull.Value)
                            fileContent.Append("\t");
                        else
                            fileContent.Append(dr[dc.ColumnName].ToString() + "\t");
                    }
                    fileContent.AppendLine();
                }
                Console.WriteLine("文件內容:");
                Console.WriteLine(fileContent.ToString());
            }
            catch (Exception ex)
            {
                Console.WriteLine("生成異常:" + ex.Message);
            }

 

  運行效果:

  
  

至此 ShiQuan.Offices Excel文件讀、寫操作項目介紹分享完畢,欲聽更多精彩,且聽下回分解!

 


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

-Advertisement-
Play Games
更多相關文章
  • 恢復內容開始 目錄 1. 分支結構 1.1 初步介紹 1.2 使用案例 1.3 練習 2.迴圈結構 1.1 初步介紹 1.2 使用案例 目錄 1. 分支結構 1.1 初步介紹 1.2 使用案例 1.3 練習 2.迴圈結構 1.1 初步介紹 1.2 使用案例 1. 分支結構 1.1 初步介紹 1.2 ...
  • ZooKeeper技術的極少以及ZooKeeper集群的搭建 ...
  • 0. 序 我從一生下來就呆在這個昏暗的地方。 我不明白為什麼程式員這麼喜歡 Dark Mode,Brighten Mode 才是我的最愛。聽說最近連 iphone 都開始支持 Dark Mode 了,沒話講。。。說好的絕不妥協呢? 我周圍是熙熙攘攘的函數群,穿插著變數聲明和巨集定義。 在我們這裡,函數 ...
  • 一、前言 應聘IC前端相關崗位時,FIFO是最常考也是最基本的題目。FIFO經常用於數據緩存、位寬轉換、非同步時鐘域處理。隨著晶元規模的快速增長,靈活的system verilog成為設計/驗證人員的基本功。本文從簡易版的同步FIFO開始,熟悉IP設計與驗證的基礎技能。 二、IP設計 FIFO這一IP ...
  • 背景 運維人員反饋一個容器化的java程式每跑一段時間就會出現OOM問題,重啟後,間隔大概兩天後復現。 問題調查 一查日誌 由於是容器化部署的程式,登上主機後使用docker logs ContainerId查看輸出日誌,並沒有發現任何異常輸出。 使用docker stats查看容器使用的資源情況, ...
  • #set指令 #set指令用於向一個變數或者對象賦值。 格式: #set($var = value) LHS是一個變數,不要使用特殊字元例如英文句號等,不能用大括弧括起來。測試發現#set($user.name = 'zhangsan'),#set(${age} = 18)均賦值失敗。 RHS可以是 ...
  • 前言 說實話,這章本來不打算講的,因為配置多數據源的網上有很多類似的教程。但是最近因為項目要用到分庫分表,所以讓我研究一下看怎麼實現。我想著上一篇博客講了多環境的配置,不同的環境調用不同的資料庫,那接下來就將一個環境用到多個庫也就講了。所以才有了這篇文章。 我們先來看一下今天項目的項目結構,在上篇博 ...
  • 最近做了一些.NET Core的程式,有在Windows下運行的 有在CentOS 下運行的,Windows下運行的還好,對Windows下還算比較熟悉了,但CentOS 下 每次都是找筆記支持命令 於是今天晚上就乾脆把以.NET Core程式已服務形式啟動的代碼封裝了下,代碼 主要是便於安裝。 我 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...