C#讀取Excel到DataTable的方法示例
前提
在Windows下進行數(shù)據(jù)處理的時候最常見的情況莫過于讀取Microsoft的Excel文件了,Excel的普及率驚人,是事實上的標準。以前的開發(fā)中我采用調用第三方類庫 NPOI 的方式來處理Excel。這個方式有兩個缺點:
- 需要依賴第三方類庫NPOI
- NPOI支持幾乎全功能的Office條件,缺點就是復雜度也高。
如果只是簡單的導入數(shù)據(jù),完全可以有更加簡單的方案,方案的限制條件為;
- 只支持Windows平臺
- 只讀取Excel文件
- 支持xls和xlsx文件格式
依賴
還是有依賴的 2007 Office System Driver: Data Connectivity Components
如果沒有安裝Driver,你會得到以下的報錯:
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 中有兩個Extended Properties可以根據(jù)需要進行修改:
- HDR,這個屬性表示Excel的第一行是不是轉換成DataTable的列名(Column Name)還是普通數(shù)據(jù)處理。
- IMEX,這個數(shù)據(jù)表明是不是讀取類型,還是全部當做文本來讀取,為了安全讀取最好設置為1,即當做文本來處理: Treat data as text 。
技巧
有時候我們需要將讀取的數(shù)據(jù)綁定到特定類型上,我們可以這樣做:
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"),
});
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
C#序列化與反序列化(Serialize,Deserialize)實例詳解
這篇文章主要介紹了C#序列化與反序列化(Serialize,Deserialize)的方法,實例分析了C#序列化與反序列化的常見技巧,需要的朋友可以參考下2015-06-06

