亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2019年04月04日 14:39:50   作者:周繼元的博客  
這篇文章主要介紹了C#讀取Excel到DataTable的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前提

在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<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#實現(xiàn)電腦系統(tǒng)掛機鎖

    基于C#實現(xiàn)電腦系統(tǒng)掛機鎖

    這篇文章主要為大家詳細介紹了如何利用C#實現(xiàn)電腦系統(tǒng)掛機鎖,文中的示例代碼講解詳細,對我們學習C#有一定的幫助,感興趣的小伙伴可以跟隨小編一起了解一下
    2022-12-12
  • c# 進程之間的線程同步

    c# 進程之間的線程同步

    這篇文章主要介紹了c# 進程之間的線程同步,幫助大家更好的理解和學習c#,感興趣的朋友可以了解下
    2020-10-10
  • 基于C#對用戶密碼使用MD5加密與解密

    基于C#對用戶密碼使用MD5加密與解密

    C#中常涉及到對用戶密碼的加密于解密的算法,其中使用MD5加密是最常見的的實現(xiàn)方式。本文總結了通用的算法并結合了自己的一點小經驗,分享給大家
    2015-12-12
  • 詳解C#如何實現(xiàn)隱式類型轉換

    詳解C#如何實現(xiàn)隱式類型轉換

    Result?類型是許多編程語言中處理錯誤的常用方式,包括?C#?的?dotNext?庫。在本文中,我們將通過例子回顧?C#?中?using?語句和隱式類型轉換的使用,感興趣的可以了解一下
    2023-01-01
  • C#中字符串的加密的源碼

    C#中字符串的加密的源碼

    C#中字符串的加密的源碼...
    2007-03-03
  • C#批量刪除Excel重復項的實現(xiàn)方法

    C#批量刪除Excel重復項的實現(xiàn)方法

    當從不同來源導入Excel數(shù)據(jù)時,可能存在重復的記錄,為了確保數(shù)據(jù)的準確性,通常需要刪除這些重復的行,本文將提供一個使用C# 快速查找并刪除Excel重復項的免費解決方案,需要的朋友可以參考下
    2024-04-04
  • C#實現(xiàn)基于Base64的加密解密類實例

    C#實現(xiàn)基于Base64的加密解密類實例

    這篇文章主要介紹了C#實現(xiàn)基于Base64的加密解密類,實例分析了C#基于Base64的加密解密實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • C#序列化與反序列化(Serialize,Deserialize)實例詳解

    C#序列化與反序列化(Serialize,Deserialize)實例詳解

    這篇文章主要介紹了C#序列化與反序列化(Serialize,Deserialize)的方法,實例分析了C#序列化與反序列化的常見技巧,需要的朋友可以參考下
    2015-06-06
  • WPF中窗體最大化問題的解決方法

    WPF中窗體最大化問題的解決方法

    這篇文章主要給大家介紹了關于WPF中窗體最大化問題的解決方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用wpf具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-10-10
  • 詳解如何將.NET應用轉換成Window服務

    詳解如何將.NET應用轉換成Window服務

    這篇文章主要為大家詳細介紹了如何將.NET8.0應用程序轉換成Windows服務,文中的示例代碼講解詳細,有需要的小伙伴可以跟隨小編一起學習一下
    2024-01-01

最新評論