在C#中讀取CSV文件的方法有兩種:一是使用StreamReader逐行讀取,適合簡單場景;二是使用CsvHelper庫處理結(jié)構(gòu)化數(shù)據(jù)。 1. 使用StreamReader時,通過ReadLine()方法逐行讀取,並用Split()按分隔符拆分字段,但需注意無法正確解析帶引號字段、無類型轉(zhuǎn)換功能。 2. CsvHelper支持自動映射類屬性、類型轉(zhuǎn)換、自定義映射、忽略列、處理帶引號字段及多種分隔符。注意事項包括:確保文件為UTF-8編碼;正確處理標題行;判斷空值;大文件建議逐行讀取以優(yōu)化性能。
在C# 中讀取CSV 文件其實不難,主要靠一些內(nèi)置類和方法來處理。如果你只是想快速讀取內(nèi)容,用StreamReader
就夠用了;如果需要更結(jié)構(gòu)化的數(shù)據(jù)處理,可以用第三方庫或者自己解析。

用StreamReader 一行行讀取
這是最基礎(chǔ)、最直接的方式,適合內(nèi)容不多、格式簡單的CSV 文件。
你可以先打開文件流,然後逐行讀取每一行的內(nèi)容,再根據(jù)逗號(或其他分隔符)把每列拆開:

using (var reader = new StreamReader("data.csv")) { while (!reader.EndOfStream) { var line = reader.ReadLine(); var values = line.Split(','); // values[0], values[1]... 就是這一行的各個字段} }
這種方式簡單有效,但需要注意幾點:
- 如果CSV 中有引號包裹的字段,比如
"New York, NY"
,直接Split 會出錯。 - 沒有自動類型轉(zhuǎn)換,所有內(nèi)容都是字符串。
用CsvHelper 簡化操作(推薦)
如果你要處理的數(shù)據(jù)比較規(guī)範,甚至有對應(yīng)的類結(jié)構(gòu),建議使用CsvHelper這個NuGet 包。

安裝好之後,可以這樣讀?。?/p>
using (var reader = new StreamReader("data.csv")) using (var csv = new CsvReader(reader, CultureInfo.InvariantCulture)) { var records = csv.GetRecords<MyClass>(); foreach (var record in records) { Console.WriteLine(record.Name); } }
這裡MyClass
是你定義的類,對應(yīng)CSV 的列名。 CsvHelper 會自動幫你映射字段、轉(zhuǎn)換類型,非常方便。
它還支持:
- 自定義字段映射
- 忽略某些列
- 處理帶引號的字段
- 支持不同分隔符(比如製表符)
注意事項和常見問題
讀取CSV 雖然看起來簡單,但有些細節(jié)容易忽略:
- 編碼問題:確保你的CSV 文件保存的是UTF-8 編碼,否則可能會出現(xiàn)亂碼。
- 首行是標題:很多CSV 第一行是列名,記得跳過或正確處理。
- 空值處理:有些字段可能是空的,注意判斷null 或空字符串。
- 大文件性能:如果文件特別大,建議按行讀取,不要一次性加載到內(nèi)存中。
基本上就這些了。選擇哪種方式取決於你的需求。如果只是簡單看一下內(nèi)容,StreamReader 就夠了;如果要做正式的數(shù)據(jù)處理,CsvHelper 會省事很多。
以上是如何在C#中讀取CSV文件?的詳細內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

熱AI工具

Undress AI Tool
免費脫衣圖片

Undresser.AI Undress
人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6
視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

自定義特性(CustomAttributes)是C#中用於向代碼元素附加元數(shù)據(jù)的機制,其核心作用是通過繼承System.Attribute類來定義,並在運行時通過反射讀取,實現(xiàn)如日誌記錄、權(quán)限控制等功能。具體包括:1.CustomAttributes是聲明性信息,以特性類形式存在,常用於標記類、方法等;2.創(chuàng)建時需定義繼承自Attribute的類,並用AttributeUsage指定應(yīng)用目標;3.應(yīng)用後可通過反射獲取特性信息,例如使用Attribute.GetCustomAttribute();

在C#中設(shè)計不可變對象和數(shù)據(jù)結(jié)構(gòu)的核心是確保對象創(chuàng)建後狀態(tài)不可修改,從而提升線程安全性和減少狀態(tài)變化導(dǎo)致的bug。 1.使用readonly字段並配合構(gòu)造函數(shù)初始化,確保字段僅在構(gòu)造時賦值,如Person類所示;2.對集合類型進行封裝,使用ReadOnlyCollection或ImmutableList等不可變集合接口,防止外部修改內(nèi)部集合;3.使用record簡化不可變模型定義,默認生成只讀屬性和構(gòu)造函數(shù),適合數(shù)據(jù)建模;4.創(chuàng)建不可變集合操作時推薦使用System.Collections.Imm

處理大量數(shù)據(jù)時,C#可通過流式處理、並行異步和合適的數(shù)據(jù)結(jié)構(gòu)實現(xiàn)高效。 1.使用流式處理逐條或分批讀取,如StreamReader或EFCore的AsAsyncEnumerable,避免內(nèi)存溢出;2.合理使用並行(Parallel.ForEach/PLINQ)與異步(async/await Task.Run),控制並發(fā)數(shù)量並註意線程安全;3.選擇高效數(shù)據(jù)結(jié)構(gòu)(如Dictionary、HashSet)和序列化庫(如System.Text.Json、MessagePack),減少查找時間和序列化開銷。

寫好C#代碼的關(guān)鍵在于可維護性和可測試性。合理劃分職責(zé),遵循單一職責(zé)原則(SRP),將數(shù)據(jù)訪問、業(yè)務(wù)邏輯和請求處理分別由Repository、Service和Controller承擔(dān),提升結(jié)構(gòu)清晰度和測試效率。多用接口和依賴注入(DI),便于替換實現(xiàn)、擴展功能和進行模擬測試。單元測試應(yīng)隔離外部依賴,使用Mock工具驗證邏輯,確??焖俜€(wěn)定執(zhí)行。規(guī)范命名和拆分小函數(shù),提高可讀性和維護效率。堅持結(jié)構(gòu)清晰、職責(zé)分明、測試友好的原則,能顯著提升開發(fā)效率和代碼質(zhì)量。

在ASP.NETCore中創(chuàng)建自定義中間件,可通過編寫類並註冊實現(xiàn)。 1.創(chuàng)建包含InvokeAsync方法的類,處理HttpContext和RequestDelegatenext;2.在Program.cs中使用UseMiddleware註冊。中間件適用於日誌記錄、性能監(jiān)控、異常處理等通用操作,與MVC過濾器不同,其作用於整個應(yīng)用,不依賴控制器。合理使用中間件可提升結(jié)構(gòu)靈活性,但應(yīng)避免影響性能。

反射是C#中用於運行時動態(tài)分析和修改程序結(jié)構(gòu)的功能,核心作用包括獲取類型信息、動態(tài)創(chuàng)建對象、調(diào)用方法及檢查程序集。常見應(yīng)用場景有:1.自動綁定數(shù)據(jù)模型,如將字典數(shù)據(jù)映射到類實例;2.實現(xiàn)插件系統(tǒng),通過加載外部DLL並調(diào)用其接口;3.支持自動化測試與日誌記錄,如執(zhí)行特定特性方法或自動記錄日誌。使用時需注意性能開銷、封裝性破壞和調(diào)試困難等問題,優(yōu)化方式包括緩存類型信息、使用委託提高調(diào)用效率及生成IL代碼等。合理利用反射可提升系統(tǒng)的靈活性與通用性。

使用LINQ時應(yīng)遵循以下要點:1.在聲明式數(shù)據(jù)操作如過濾、轉(zhuǎn)換或聚合數(shù)據(jù)時優(yōu)先使用LINQ,避免在有副作用或性能關(guān)鍵的場景強制使用;2.理解延遲執(zhí)行特性,源集合修改可能導(dǎo)致意外結(jié)果,需根據(jù)需求選擇延遲或立即執(zhí)行;3.注意性能與內(nèi)存開銷,鍊式調(diào)用可能產(chǎn)生中間對象,性能敏感代碼可改用循環(huán)或Span;4.保持查詢簡潔易讀,複雜邏輯拆分為多個步驟,避免過度嵌套和混合多種操作。

泛型約束用於限制類型參數(shù)以確保特定行為或繼承關(guān)係,協(xié)變則允許子類型轉(zhuǎn)換。例如,whereT:IComparable確保T可比較;協(xié)變?nèi)鏘Enumerable允許IEnumerable轉(zhuǎn)為IEnumerable,但僅限讀取,不可修改。常見約束包括class、struct、new()、基類和接口,多約束用逗號分隔;協(xié)變需用out關(guān)鍵字且只適用於接口和委託,與逆變(in關(guān)鍵字)不同。注意協(xié)變不支持類,不能隨意轉(zhuǎn)換,且約束影響靈活性。
