最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
C#讀取Excel到DataTable的方法示例

前提

成都創(chuàng)新互聯(lián)公司專注于企業(yè)網(wǎng)絡營銷推廣、網(wǎng)站重做改版、衡陽網(wǎng)站定制設計、自適應品牌網(wǎng)站建設、H5網(wǎng)站設計、商城網(wǎng)站開發(fā)、集團公司官網(wǎng)建設、成都外貿(mào)網(wǎng)站建設、高端網(wǎng)站制作、響應式網(wǎng)頁設計等建站業(yè)務,價格優(yōu)惠性價比高,為衡陽等各大城市提供網(wǎng)站開發(fā)制作服務。

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

  1. 需要依賴第三方類庫NPOI
  2. 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("phoneNumber") != string.Empty)
  .Select(x => new Contact
    {
      FirstName= x.Field("First Name"),
      LastName = x.Field("Last Name"),
      PhoneNumber =x.Field("Phone Number"),
    });

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


網(wǎng)站題目:C#讀取Excel到DataTable的方法示例
當前路徑:http://fisionsoft.com.cn/article/gssgdj.html