国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C#讀取Excel到DataTable的方法示例

2020-01-24 00:06:19
字體:
來源:轉載
供稿:網友

前提

在Windows下進行數據處理的時候最常見的情況莫過于讀取Microsoft的Excel文件了,Excel的普及率驚人,是事實上的標準。以前的開發中我采用調用第三方類庫 NPOI 的方式來處理Excel。這個方式有兩個缺點:

  1. 需要依賴第三方類庫NPOI
  2. NPOI支持幾乎全功能的Office條件,缺點就是復雜度也高。

如果只是簡單的導入數據,完全可以有更加簡單的方案,方案的限制條件為;

  • 只支持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可以根據需要進行修改:

  • HDR,這個屬性表示Excel的第一行是不是轉換成DataTable的列名(Column Name)還是普通數據處理。
  • IMEX,這個數據表明是不是讀取類型,還是全部當做文本來讀取,為了安全讀取最好設置為1,即當做文本來處理: Treat data as text

技巧

有時候我們需要將讀取的數據綁定到特定類型上,我們可以這樣做:

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"),    });

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 牡丹江市| 沁源县| 河北省| 焦作市| 布尔津县| 乌恰县| 云梦县| 吐鲁番市| 乐安县| 合山市| 娱乐| 壶关县| 洞头县| 兴隆县| 靖州| 林芝县| 蓝田县| 清丰县| 高淳县| 乌审旗| 牟定县| 广平县| 淮南市| 淅川县| 文水县| 博爱县| 衡山县| 新干县| 清水县| 冀州市| 大名县| 襄垣县| 门源| 教育| 中宁县| 澄迈县| 孟连| 宁夏| 乌兰察布市| 乌海市| 上高县|