c# ClosedXML.Report excel報表排坑

来源:https://www.cnblogs.com/chenzhaojie/archive/2020/05/10/12862622.html
-Advertisement-
Play Games

一.介紹ClosedXML.Report ClosedXML.Report開源報表 支持net4.0+。 github:https://github.com/ClosedXML/ClosedXML.Report github項目下載慢參考:https://blog.csdn.net/czjnoe/a ...


一.介紹ClosedXML.Report

      ClosedXML.Report開源報表  支持net4.0+。

  github:https://github.com/ClosedXML/ClosedXML.Report

  github項目下載慢參考:https://blog.csdn.net/czjnoe/article/details/106034095

       一個可以生成Excel報表的工具,創建一份xlsx 模板,設置數據填充規則,然後直接填充數據即可快速轉換為 Excel報表。

   在網上沒有找到較好ClosedXML.Report的示例,而且官方提供的使用示例實在太坑人了,也許該博主太"懶惰"了,所以今天寫下該文章,方便後來者的使用,以免入坑太久。

    

二.如何使用

1.首先創建xlsx模板

 註意:上圖紅色區域,需要在excel中,設置區功能變數名稱稱為item,否則無法填充數據

2.c# demo示例

首先添加ClosedXML(0.95.0.0)、ClosedXML.Report(0.2.0.0),不要在nuget直接下載,最好下載官方開源項目,引用項目下的dll,或者直接使我的demo中的引用,在文章末尾

創建所需實體:

public class Student
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public int Age { get; set; }
    }

public class Course
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public double Grade { get; set; }
        public item Items { get; set; }
    }
    public class item
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }

代碼示例:

 const string outputFile = @".\Output\report.xls";//輸出目錄
            var template = new XLTemplate(@".\Template\Student.xls");//模板目錄

            Student stu = new Student
            {
                Age = 25,
                Id = 1,
                Name = "財政局",
            };
            Dictionary<string, string> dic = new Dictionary<string, string>();
            dic["Id"] = "1";
            dic["Age"] = "25";
            dic["Name"] = "財政局";


            //AddVariable(object)方法,可傳入實體、字典
            {
                //template.AddVariable(stu);//傳入單個實體

                template.AddVariable(dic);//傳入字典
            }

            //AddVariable(string alias, object value)方法,可以傳入集合、動態類型、DataTable。如果希望輸出多個table表,建議傳入集合
            //註意key值必須為item
            {
                IEnumerable<dynamic> CourseItems()
                {
                    return new List<dynamic>
                {
                    new { Id=1, Name="數學", Grade=89,Items=new { Id=1,Name="1"} },
                    new { Id=2, Name="英語", Grade=15,Items=new { Id=2,Name="2"} },
                    new { Id=3, Name="語文", Grade=100,Items=new { Id=3,Name="3"} },
                };
                }

                var Course = new List<Course>
                 {
                      new Course{ Id=1, Name="數學", Grade=89 , Items=new item{ Id=1,Name="1"}},
                      new Course{ Id=2, Name="英語", Grade=15, Items=new item{ Id=2,Name="2"}},
                      new Course{ Id=3, Name="語文", Grade=100, Items=new item{ Id=3,Name="3"}}
                 };
                DataTable dt = new DataTable();
                dt.Columns.Add("Id", typeof(int));
                dt.Columns.Add("Name", typeof(string));
                dt.Columns.Add("Grade", typeof(int));

                var newRow = dt.NewRow();
                newRow["Id"] = 1;
                newRow["Name"] = "數學";
                newRow["Grade"] = 89;
                dt.Rows.Add(newRow);
                newRow = dt.NewRow();
                newRow["Id"] = 2;
                newRow["Name"] = "英語";
                newRow["Grade"] = 15;
                dt.Rows.Add(newRow);
                newRow = dt.NewRow();
                newRow["Id"] = 3;
                newRow["Name"] = "語文";
                newRow["Grade"] = 100;
                dt.Rows.Add(newRow);


                //template.AddVariable("item", CourseItems());//動態類型
                template.AddVariable("item", Course);//集合 key必須為item
                //template.AddVariable("item", dt);//DataTable
            }

            template.Generate();

            template.SaveAs(outputFile);//輸出excel文件

            //打開excel文件
            Process.Start(new ProcessStartInfo(outputFile) { UseShellExecute = true });

 

3.輸出excel:

 

 

 

三.總結

    如果你只是處理一些簡單的報表輸出或只需要輸出一張table表,還是可以使用的,畢竟比npoi輸出簡單多了,否則不建議使用

   ClosedXML.Report缺點:
      1.只能處理簡單的數據插入,如果想要輸出多個table表的話,則會麻煩一點,這點非常不友好。
      2.輸出表格table,需要指定excel一塊區域,且把該區域設置名稱為item。
      3.不支持xls格式。只支持如下格式。'.xlsx', '.xlsm', '.xltx' and '.xltm'.

            我的demo:https://gitee.com/czjnoe/ClosedXML.ReportDemo

 


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

-Advertisement-
Play Games
更多相關文章
  • 大家好,這是“Python為什麼”系列節目的文字稿( 文末有觀看地址 )。 本期話題:Python 為什麼使用縮進來劃分代碼塊,而不像其它語言使用花括弧 {} 或者 “end” 之類的語法? Python 的縮進是一個老生常談的話題,經常有人會提及它,比如 Python 之父在上個月就恰好轉發過一篇 ...
  • 存儲持續性:自動 作用域:局部(起點:聲明位置) 鏈接性:無 分配記憶體:執行到代碼塊時 存儲方式:棧(LIFO 後進先出) 註意: 執行內部代碼塊時,新定義隱藏以前的定義,舊定義暫時不可見,離開代碼塊後重見 ...
  • 前言 Nacos最近項目一直在使用,其簡單靈活,支持更細粒度的命令空間,分組等為麻煩複雜的環境切換提供了方便;同時也很好支持動態路由的配置,只需要簡單的幾步即可。在國產的註冊中心、配置中心中比較突出,容易上手,本文通過gateway、nacos-consumer、nacos-provider三個簡單 ...
  • 1、JVM的位置:JVM是在操作系統上面的應用軟體 JVM虛擬機有三種如下: ① Sun公司的HotSpot; ② BEA公司的JRockit; ③ IBM公司的J9 JVM; java虛擬機屬於第一種: 2、JVM的體繫結構: 3、類載入器 作用:載入class文件 (類是模板,對象是具體的) 簡 ...
  • 視頻:https://www.bilibili.com/video/BV15x411x7WN?p=5 新建Devexpress Winform BlankApplication。 添加GridControl,Change View為LayoutView。 添加LayoutViewColumn,設置C ...
  • 一、在Jenkins中安裝Nunit插件進入jenkins的插件管理模塊,下載Nunit插件。此步驟不做截圖說明二、引用nunit.console的nuget包通過項目引用Nunit.console包 然後可以packages\NUnit.ConsoleRunner.3.11.1\tools文件夾查 ...
  • 一、發佈配置差異配置:編譯內容編譯目標NetWorkClient/KJ90NetClient.csproj編譯命令/t:build/p:Configuration=Release /p:OutputPath=../UploadRelease運行外部程式二、配置jenkins啟動外部程式不報錯通過參數... ...
  • 項目模板簡介 眾所周知,在我們使用VS新建項目時,都需要選擇一個項目模板,如下圖: 我們選擇完項目模板進行創建,創建完成之後,可以發現項目中已經包含了一些基礎的文件。例如MVC: 可以看到,MVC項目下,這麼多的文件、類都給我們自動生成了,我們並不需要敲任何代碼。 所以,項目模板,就是在我們創建新項 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...