一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - ASP.NET(C#) 讀取EXCEL另加解決日期問題的方法分享

ASP.NET(C#) 讀取EXCEL另加解決日期問題的方法分享

2019-11-21 13:27ASP.NET教程網 ASP.NET教程

這篇文章介紹了ASP.NET(C#) 讀取EXCEL另加解決日期問題的方法,有需要的朋友可以參考一下

使用OLEDB可以對excel文件進行讀取,我們只要把該excel文件作為數據源即可。

一 在D盤創建excel文件test.xls:

ASP.NET(C#) 讀取EXCEL另加解決日期問題的方法分享

二 將工作表Sheet1的內容讀取到DataSet

復制代碼代碼如下:

  string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:/test.xls;"+
      "Extended Properties='Excel 8.0'";
  DataSet ds = new DataSet();
  OleDbDataAdapter oada = new OleDbDataAdapter("select * from [Sheet1$]", strConn);
  oada.Fill(ds);


讀取的DataSet為:
ASP.NET(C#) 讀取EXCEL另加解決日期問題的方法分享

從圖中可以看出excel文件中的第一行變成了DataSet中的列名,這正是系統的默認設置。

三 如果想把第一行也作為數據行,那我們可以給連接字符串添加一個HDR=No屬性如:

復制代碼代碼如下:

  string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:/test.xls;"+
      "Extended Properties='Excel 8.0;HDR=No'";
  DataSet ds = new DataSet();
  OleDbDataAdapter oada = new OleDbDataAdapter("select * from [Sheet1$]", strConn);
  oada.Fill(ds);


  結果也許會讓你有點想不到:

ASP.NET(C#) 讀取EXCEL另加解決日期問題的方法分享

第一行的第一列和第三列都變成空的了,這是因為系統把第一列識別成了數字,把第三列識別成了日期,

而第一行的數據不符合格式的要求,所以就變成空的了。

四 我們還可以把所有列都做為字符串來讀取,只要添加屬性IMEX=1即可

復制代碼代碼如下:

  string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:/test.xls;"+
      "Extended Properties='Excel 8.0;HDR=No;IMEX=1'";
  DataSet ds = new DataSet();
  OleDbDataAdapter oada = new OleDbDataAdapter("select * from [Sheet1$]", strConn);
  oada.Fill(ds);


  結果又會如何呢?

ASP.NET(C#) 讀取EXCEL另加解決日期問題的方法分享

是不是再次出乎你的意料,第三行的日期怎么變成數字了,其實excel在轉換格式的時候就自動把日期變成數字了,

那這個數字是怎么來的呢 ? 如果你把日期改成1900年1月1日,那么你可以看到他的轉換結果是1,以此類推,39902是哪一天就明白了吧。

這里解決辦法:

方法一:

復制代碼代碼如下:


  public static string getDateStr(string strValue)
      {
          int i = Convert.ToInt32(strValue);
          DateTime d1 = Convert.ToDateTime("1900-1-1");
          DateTime d2 = d1.AddDays(i - 2);
          string strTemp = d2.ToString("d");

 

          return strTemp;
      }


方法二:

復制代碼代碼如下:

  DateTime.FromOADate(Convert.ToInt32(strValue)).ToString("d");


五 也許你并不想讀取整個excel的內容

 

如果只想讀取前兩列可以用:select * from [Sheet1$A:B]

如果只想讀取A1到B2的內容,就用:select * from [Sheet1$A1:B2]

六 如果不知道工作表的名字或名字被人為修改了該怎么辦呢?

我們可以通過索引來獲取指定工作表的名字,以下方法可以用來獲取工作表名稱的數組:

 

復制代碼代碼如下:

  ArrayList al = new ArrayList();
  string strConn;
  strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:/test.xls;"+
      "Extended Properties=Excel 8.0;";
  OleDbConnection conn = new OleDbConnection(strConn);
  conn.Open();
  DataTable sheetNames = conn.GetOleDbSchemaTable
      (OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
  conn.Close();
  foreach (DataRow dr in sheetNames.Rows)
  {
      al.Add(dr[2]);
  }
  return al;


 

 

IMEX=1的時候并不是全都會作為字符串來處理,根據系統的默認設置,通常如果前8行有字符串,則該列會作為字符串來處理,如果全都為數字,則該列為數字列,日期也是一樣。

如果你覺得8行不夠或者太多了,則只能修改注冊表HKEY_LOCAL_MACHINE/Software/Microsoft/Jet/4.0/Engines/Excel/TypeGuessRows,如果此值為0,則會根據所有行來判斷使用什么類型,通常不建議這麼做,除非你的數據量確實比較少。

無法讀取EXCEL中的數據單元格。有數據,但是讀出來全是空值。

解決方法:

1.在導入數據連接字符串中,將IMEX=1加入,“Provider=Microsoft.Jet.OLEDB.4.0;Data Source="C:\Data.xls";Extended Properties="Excel 8.0;HDR=Yes;IMEX=1; ”,這樣就可以。

注:

“HDR=Yes;”指示第一行中包含列名,而不是數據;

“IMEX=1;”通知驅動程

序始終將“互混”數據列作為文本讀取。

兩者必須一起使用。

本以為這樣就OK了。但在實際使用過程中,這樣設置還是不行,查閱了不少資料才發現,原來還有一個注冊表里的信息需要修改,這樣帶能讓excel不再使用前8行的內容來確定該列的類型。

注冊表修改內容如下:

在HKEY_LOCAL_MACHINE\Software\Microsoft\Jet\4.0\Engines\Excel有一個TypeGuessRows值,預設是8,表示會先讀取前8列來決定每一個欄位的型態,所以如果前8列的資料都是數字,到了第9列以后出現的文字資料都會變成null,所以如果要解決這個問題,只要把TypeGuessRows機碼值改成0,就可以解這個問題了。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩综合第一页 | 久久精品AV一区二区无码 | 天天有好逼| 日本人黄色 | 午夜私人福利影院 | 精品国产成人 | 好男人资源免费观看 | 99精品国产高清自在线看超 | 水多多凹凸福利视频导航 | 免费视屏| 99国产精品久久久久久久... | 精品一区二区三区自拍图片区 | 99爱在线观看 | 亚洲人尿尿 | 兽皇videos日本另类 | 男人的影院 | 免费看一级大片 | 亚洲第一永久色 | 国产在线观看一区 | 欧美milk大超乳 | 国产女主播福利在线 | jiizz亚洲护士厕所 | 久久久久久久国产精品视频 | 成人123 | 火影忍者小南裸羞羞漫画 | 91探花在线观看 | 大学生宿舍飞机china free | 天天综合天天影视色香欲俱全 | 2012手机在线中文字幕 | 精品欧美一区二区三区四区 | 男人狂擦女人的下面视频 | 亚洲成人一区在线 | 亚洲视频在线免费看 | 国产裸露片段精华合集链接 | 美女靠逼免费网站 | caopren免费视频国产 | 99任你躁精品视频 | 桥本有菜ssni-677在线观看 | 无人在线观看免费高清视频播放 | 亚洲第99页 | 含羞草传媒每天免费一次破解 |