C#使用Linq to csv讀取.csv文件數據

来源:https://www.cnblogs.com/lxhbky/archive/2019/11/18/11884474.html
-Advertisement-
Play Games

今日遇到了一個需要讀取CSV文件類型的EXCEL文檔數據的問題,原本使用NPOI的解決方案直接讀取文檔數據,最後失敗了,主要是文件的類型版本等信息不相容導致。其他同事有使用linq to csv的Nuget包,獲取CSV文件數據的方式,感覺寫法非常簡單,且很快實現了我的需求,現分享給大家參考使用:L... ...


  前言:今日遇到了一個需要讀取CSV文件類型的EXCEL文檔數據的問題,原本使用NPOI的解決方案直接讀取文檔數據,最後失敗了,主要是文件的類型版本等信息不相容導致。其他同事有使用linq to csv的Nuget包,獲取CSV文件數據的方式,感覺寫法非常簡單,且很快實現了我的需求,現分享給大家參考使用:

  LinqToCsv官方資料:https://www.codeproject.com/Articles/25133/LINQ-to-CSV-library  

 

  1-引用Nuget包:LinqToCsv:https://www.nuget.org/packages/LinqToCsv

  2-創建CSV幫助類:

public class CSVHelper
    {
        public static List<T> Read<T>(string path, CsvFileDescription fileDescription) where T : class, new()
        {
            CsvContext _csv = new CsvContext();
            return _csv.Read<T>(path, fileDescription).ToList();
        }
        public static List<T> Read<T>(string path) where T : class, new()
        {
            CsvContext _csv = new CsvContext();
            CsvFileDescription _fileDescription = new CsvFileDescription()
            {
                //首列數據是否含有列名
                FirstLineHasColumnNames = true,
                //是否啟用CsvColumn屬性標記
                EnforceCsvColumnAttribute = true,
                //是否忽略未知的行
                IgnoreUnknownColumns = true,
                //是否啟用OutputFormat格式轉換數據
                UseOutputFormatForParsingCsvValue = true,
                //是否啟用屬性下標讀取數據
                UseFieldIndexForReadingData = true,
                //文本編碼格式
                TextEncoding = Encoding.UTF8
            };
            return _csv.Read<T>(path, _fileDescription).ToList();
        }
    }

  3-創建接受類T:

  備註:

  特性-Name:表示映射的列名;

  FieldIndex:映射的位置;舉例中未按照順序寫全,請自行補充;

  CanBeNull:是否可以為Null;

  OutputFormat:數據格式化字元串方式;   啟用時間格式使用yyyyMMddHHmmss自己根據數據調整;    含有小數點位的標記為C;   其他的類型請查閱資料

public class WP
        {
            /// <summary>
            /// 管理代碼
            /// </summary>
            [CsvColumn(Name = "Administration Code", FieldIndex = 1, CanBeNull = false)]
            public string AdministrationCode { get; set; }/// <summary>
            /// 日期
            /// </summary>
            [CsvColumn(Name = "Date", FieldIndex = 4, CanBeNull = false, OutputFormat = "yyyy-MM-dd HH:mm:ss")]
            public DateTime Date { get; set; }/// <summary>
            /// 支付金額
            /// </summary>
            [CsvColumn(Name = "Amount", FieldIndex = 8, CanBeNull = false, OutputFormat = "C")]
            public decimal Amount { get; set; }
        }

  4-使用方式:

CSVHelper.Read<OrderTransaction.WP>(filePath);

 

  5-待解決疑問:

  上面的代碼可以解決規範的CSV文件數據的讀取(即CSV文件中不包含其他雜亂數據),如果文檔的前幾行含有一些其他說明信息的話,那麼數據的讀取可能遇到問題。而包里並沒有提供可以設置開始讀取數據的行數,所以,有點遺憾!


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

-Advertisement-
Play Games
更多相關文章
  • 一.if邏輯判斷 二.switch 方式一 方式二 關鍵字fallthrough的使用 ...
  • FluentValidation在C# WPF中應用,支持嵌套屬性驗證。 ...
  • C#.net系列後端知識點彙總(也有些許資料庫、svn等),他山之石。 1..net相關技術:XML、webservice、SOAP,其中webservice使用三大技術:XML、SOAP、WSDL。 也有一說webservice三要素: 2.分散式:分散式作業、分散式存儲。 3.資料庫縱向切割、橫 ...
  • 1.五個動詞 ①GET:讀取(Read) 查詢操作 ②POST:新建(Create) 添加操作 ③PUT:更新(Update) 修改操作 ④PATCH:更新(Update),通常是部分更新 修改操作 ⑤DELETE:刪除(Delete) 刪除操作 2.狀態碼 首先狀態碼可以大致分為五類: ①2XX ...
  • class Program { static void Main(string[] args) { int[] arr = { 8, 15, 16, 11, 99, 4 }; for (int i = 0; i <arr.Length-1 ; i++) { for (int j = 0; j <ar ...
  • 本文主要是為瞭解決上面博客遺留的一個含有不規範數據的一種方法,目前暫時沒有從包里發現可以從第N行讀取數據方法,但是我們可以假設一種情況來相容目前的數據:   超級假設:假設Excel所有的數據都是我要收集的數據,不管是否有數據或者是不規範的數據,那麼我可以將接受類的數據類型統一改為string,其... ...
  • 故事背景 最近在把自己的一個老項目從Framework遷移到.Net Core 3.0,數據訪問這塊選擇的是EFCore+Mysql。使用EF的話不可避免要和DbContext打交道,在Core中的常規用法一般是:創建一個XXXContext類繼承自DbContext,實現一個擁有DbContext ...
  • 前言 有小半年沒寫博客了,今年以來,感覺格外忙,再者,這半年代碼寫得相對少,做項目管理、出差、瑣事多了,實在是慚愧。Java、前端、SQL還擼了一些,.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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...