讓 .NET 更方便的導入導出 Excel

来源:https://www.cnblogs.com/weihanli/archive/2018/11/22/10004614.html
-Advertisement-
Play Games

讓 .Net 更方便的導入導出Excel Intro 因為前一段時間需要處理一些 excel 數據,主要是導入/導出操作,將 Excel 數據轉化為對象再用程式進行處理和分析,沒有找到比較滿意的庫,於是就自己造了一個輪子,屏蔽掉了 xlsx 與 xls 的差別,屏蔽了 Npoi 操作 Excel 的 ...


讓 .Net 更方便的導入導出Excel

Intro

因為前一段時間需要處理一些 excel 數據,主要是導入/導出操作,將 Excel 數據轉化為對象再用程式進行處理和分析,沒有找到比較滿意的庫,於是就自己造了一個輪子,屏蔽掉了 xlsx 與 xls 的差別,屏蔽了 Npoi 操作 Excel 的細節,提供簡單容易上手的 api。

導入/導出

直接添加 nuget 包引用 WeihanLi.Npoi

根據 excel 文件獲取一個 IWorkbook 對象,支持 *.xls/*.xlsx

IWorkbook workbook = ExcelHelper.LoadExcel("excelFilePath");

將 Excel 文件的第一個 sheet 里的內容轉成 list 對象

List<TEntity> entityList = ExcelHelper.ToEntityList<TEntity>("excelFilePath");

將 Excel 文件的第一個 sheet 里的內容轉成 DataTable 對象

DataTable dataTable = ExcelHelper.ToDataTable("excelFilePath");

將 list 對象導出到 Excel 位元組數組

List<TEntity> entityList = ExcelHelper.ToEntityList<TEntity>("excelFilePath");

entityList.ToExcelBytes();

將 list 對象導出到 Excel 文件

List<TEntity> entityList = ExcelHelper.ToEntityList<TEntity>("excelFilePath");

entityList.ToExcelFile("excelFilePath");

More

想要更多自定義選項,參考示例項目,或者給我提 issue

Contact

如果使用過程中有遇到什麼問題,歡迎與我聯繫。

Contact me: [email protected]


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

-Advertisement-
Play Games
更多相關文章
  • Python基礎知識(10):函數(Ⅱ) 一、全局變數和局部變數 局部變數:在函數內定義的變數,在函數內使用 全局變數:在函數外定義的變數,在程式任何地方都可以使用 1、全局變數與局部變數同名 這時函數內部只調用局部變數,如果要調用全局變數需要在函數內加一句“global 同名變數” 結果:1 2、 ...
  • 首先請看下麵的程式: 1. 註釋 2.對中文的支持 python2和python3不一樣,python3預設支持,python2 需要加上 3.變數 為了更充分的利用記憶體空間以及更有效率的管理記憶體,變數是有不同的類型的,如下所示 怎樣知道一個變數的類型呢? 在python中,只要定義了一個變數,而且 ...
  • Arraylist 與 LinkedList 異同 1. 是否保證線程安全: ArrayList 和 LinkedList 都是不同步的,也就是不保證線程安全; 2. 底層數據結構: Arraylist 底層使用的是Object數組;LinkedList 底層使用的是雙向迴圈鏈表數據結構; 3. 插 ...
  • 十五、首頁全局配置 1、首頁前端頁面配置 將index.html繼承base.html頁面,修改繼承的block地方: 修改base.html頁面中導航欄選中狀態的代碼: 2、全局搜索功能 首頁的全局搜索功能可以對課程,機構,教師進行全局搜索,搜索的代碼放在deco-common.js文件中: 只需 ...
  • PHP代碼的執行:1.和大部分程式一樣,接收數據,處理數據,輸出結果2.編寫的代碼就是輸入的數據,php內核進行處理,返回相應的輸出3.php作為業務程式和編譯語言的區別就是,php多了一步把用戶代碼翻譯為機器語言的步驟:詞法分析,語法分析4.詞法分析把php代碼分割成一個個單元,語法分析將這些單元 ...
  • django+uwsgi+nginx部署 1.介紹: 在網上看了很多教程,但自己部署了很久都沒有成功,這篇博文記錄自己所踩過得坑。 2.環境: 3.下載uwsgi以及nginx (註:如果下載異常出現許可權問題,在命令前添加sudo) 4.創建Django項目 例如:項目名為mysite 說明:Lin ...
  • public class SwitchCase { public static void main(String[] args) { System.out.println(switchFun(4)); //運行結果:8 } public static int switchFun(int x){ in... ...
  • ASP.NET -- WebForm -- 頁面生命周期 ASP.NET 頁運行時,此頁將經歷一個生命周期,在生命周期中將執行一系列處理步驟。這些步驟包括初始化、實例化控制項、還原和維護狀態、運行事件處理程式代碼以及進行呈現。瞭解頁生命周期非常重要,因為這樣做您就能在生命周期的合適階段編寫代碼,以達到 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...