C#讀取Excel到DataTable的方法示例
前提
在Windows下進(jìn)行數(shù)據(jù)處理的時(shí)候最常見(jiàn)的情況莫過(guò)于讀取Microsoft的Excel文件了,Excel的普及率驚人,是事實(shí)上的標(biāo)準(zhǔn)。以前的開(kāi)發(fā)中我采用調(diào)用第三方類(lèi)庫(kù) NPOI 的方式來(lái)處理Excel。這個(gè)方式有兩個(gè)缺點(diǎn):
- 需要依賴(lài)第三方類(lèi)庫(kù)NPOI
- NPOI支持幾乎全功能的Office條件,缺點(diǎn)就是復(fù)雜度也高。
如果只是簡(jiǎn)單的導(dǎo)入數(shù)據(jù),完全可以有更加簡(jiǎn)單的方案,方案的限制條件為;
- 只支持Windows平臺(tái)
- 只讀取Excel文件
- 支持xls和xlsx文件格式
依賴(lài)
還是有依賴(lài)的 2007 Office System Driver: Data Connectivity Components
如果沒(méi)有安裝Driver,你會(huì)得到以下的報(bào)錯(cuò):
Microsoft.ACE.OLEDB.12.0' provider is not registered on the local machine
代碼
public static DataTable ReadAsTable(string xlsxFile, string sheetName = "Sheet1") { var connectionString = string.Format("Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties=\"Excel 12.0;HDR=Yes;IMEX=1\"", xlsxFile); var adapter = new OleDbDataAdapter($"SELECT * FROM [{sheetName}$]", connectionString); var ds = new DataSet(); adapter.Fill(ds, sheetName); return ds.Tables[sheetName]; }
在 connectionString 中有兩個(gè)Extended Properties可以根據(jù)需要進(jìn)行修改:
- HDR,這個(gè)屬性表示Excel的第一行是不是轉(zhuǎn)換成DataTable的列名(Column Name)還是普通數(shù)據(jù)處理。
- IMEX,這個(gè)數(shù)據(jù)表明是不是讀取類(lèi)型,還是全部當(dāng)做文本來(lái)讀取,為了安全讀取最好設(shè)置為1,即當(dāng)做文本來(lái)處理: Treat data as text 。
技巧
有時(shí)候我們需要將讀取的數(shù)據(jù)綁定到特定類(lèi)型上,我們可以這樣做:
var query = dt .AsEnumerable() .Where(x => x.Field<string>("phoneNumber") != string.Empty) .Select(x => new Contact { FirstName= x.Field<string>("First Name"), LastName = x.Field<string>("Last Name"), PhoneNumber =x.Field<string>("Phone Number"), });
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C#使用NPOI實(shí)現(xiàn)Excel和DataTable的互轉(zhuǎn)
- C#實(shí)現(xiàn)Json轉(zhuǎn)DataTable并導(dǎo)出Excel的方法示例
- C#使用Datatable導(dǎo)出Excel
- c# 將Datatable數(shù)據(jù)導(dǎo)出到Excel表格中
- C#實(shí)現(xiàn)將DataTable內(nèi)容輸出到Excel表格的方法
- C#使用oledb讀取excel表格內(nèi)容到datatable的方法
- C#操作EXCEL DataTable轉(zhuǎn)換的實(shí)例代碼
- C#如何將DataTable導(dǎo)出到Excel解決方案
- C#把EXCEL數(shù)據(jù)轉(zhuǎn)換成DataTable
相關(guān)文章
基于C#實(shí)現(xiàn)電腦系統(tǒng)掛機(jī)鎖
這篇文章主要為大家詳細(xì)介紹了如何利用C#實(shí)現(xiàn)電腦系統(tǒng)掛機(jī)鎖,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C#有一定的幫助,感興趣的小伙伴可以跟隨小編一起了解一下2022-12-12詳解C#如何實(shí)現(xiàn)隱式類(lèi)型轉(zhuǎn)換
Result?類(lèi)型是許多編程語(yǔ)言中處理錯(cuò)誤的常用方式,包括?C#?的?dotNext?庫(kù)。在本文中,我們將通過(guò)例子回顧?C#?中?using?語(yǔ)句和隱式類(lèi)型轉(zhuǎn)換的使用,感興趣的可以了解一下2023-01-01C#批量刪除Excel重復(fù)項(xiàng)的實(shí)現(xiàn)方法
當(dāng)從不同來(lái)源導(dǎo)入Excel數(shù)據(jù)時(shí),可能存在重復(fù)的記錄,為了確保數(shù)據(jù)的準(zhǔn)確性,通常需要?jiǎng)h除這些重復(fù)的行,本文將提供一個(gè)使用C# 快速查找并刪除Excel重復(fù)項(xiàng)的免費(fèi)解決方案,需要的朋友可以參考下2024-04-04C#實(shí)現(xiàn)基于Base64的加密解密類(lèi)實(shí)例
這篇文章主要介紹了C#實(shí)現(xiàn)基于Base64的加密解密類(lèi),實(shí)例分析了C#基于Base64的加密解密實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03C#序列化與反序列化(Serialize,Deserialize)實(shí)例詳解
這篇文章主要介紹了C#序列化與反序列化(Serialize,Deserialize)的方法,實(shí)例分析了C#序列化與反序列化的常見(jiàn)技巧,需要的朋友可以參考下2015-06-06詳解如何將.NET應(yīng)用轉(zhuǎn)換成Window服務(wù)
這篇文章主要為大家詳細(xì)介紹了如何將.NET8.0應(yīng)用程序轉(zhuǎn)換成Windows服務(wù),文中的示例代碼講解詳細(xì),有需要的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01