亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

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

2024-07-10 13:15:06
字體:
來源:轉載
供稿:網友

使用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网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
在线播放国产精品| 国产欧美日韩中文字幕在线| 亚洲成人精品在线| 久久久久久久久久国产| 热久久美女精品天天吊色| 久久手机免费视频| 亚洲第一av网| 国产剧情日韩欧美| 亚洲第一福利视频| 久久夜精品va视频免费观看| 国产精品一区二区女厕厕| 欧美在线免费视频| 欧美激情精品久久久久久| 91影院在线免费观看视频| 亚洲激情在线观看视频免费| 国产一区二区丝袜高跟鞋图片| 91国内揄拍国内精品对白| 国产精品福利在线| 一区二区三区日韩在线| 丝袜情趣国产精品| 亚洲在线观看视频| 一区二区三区在线播放欧美| 91在线高清视频| 色系列之999| 国产精品美女久久| 日韩成人激情在线| 高跟丝袜一区二区三区| 自拍偷拍亚洲欧美| 日韩精品一区二区视频| 久久韩国免费视频| 欧美激情视频在线免费观看 欧美视频免费一| 91亚洲精品久久久久久久久久久久| 在线丨暗呦小u女国产精品| 亚洲高清免费观看高清完整版| 久久精品国产久精国产一老狼| 欲色天天网综合久久| 国产精品成久久久久三级| 久久夜精品va视频免费观看| 国产精品免费电影| 欧美中文字幕在线视频| 久久九九国产精品怡红院| 成人信息集中地欧美| 欧美激情一区二区三区久久久| 欧美激情videos| 欧美在线观看网址综合| 91禁外国网站| 国产精彩精品视频| 久久久久久久久久久免费| 中文字幕精品一区二区精品| 久热精品在线视频| 午夜精品一区二区三区在线| 日韩av网站导航| 日韩精品免费在线观看| 国产69久久精品成人| 亚洲欧美日韩天堂一区二区| 91亚洲精品久久久久久久久久久久| 久久91精品国产91久久久| 中文字幕亚洲综合久久筱田步美| 精品久久久在线观看| 一区二区欧美亚洲| 亚洲欧美日韩第一区| www日韩中文字幕在线看| 91丨九色丨国产在线| 欧美激情乱人伦| 成人国产精品日本在线| 亚洲一区二区三区在线免费观看| 久久久久久久97| 久久久久久香蕉网| 日本不卡高字幕在线2019| 国产成人97精品免费看片| 日韩大胆人体377p| 57pao成人永久免费视频| 亚洲天堂网站在线观看视频| 久久人人爽人人爽人人片av高请| 欧美国产日韩精品| 一区国产精品视频| 黄网站色欧美视频| 国产精品永久免费观看| 韩国v欧美v日本v亚洲| 亚洲女人被黑人巨大进入| 日韩中文字幕在线视频| 欧美劲爆第一页| 欧美三级欧美成人高清www| 久久全国免费视频| 欧美在线视频一区二区| 日韩综合中文字幕| 中文字幕亚洲无线码a| 最新91在线视频| 97视频在线观看视频免费视频| 国产精品扒开腿做| 91亚洲精品在线观看| 欧美亚洲第一区| 日韩久久免费电影| 这里只有精品在线播放| 欧美性猛交xxxx乱大交极品| 精品露脸国产偷人在视频| 日产精品久久久一区二区福利| 97视频在线观看免费高清完整版在线观看| 中文字幕欧美日韩在线| 欧美激情乱人伦一区| 亚洲国产精品悠悠久久琪琪| 精品欧美aⅴ在线网站| 日韩第一页在线| 久久色精品视频| 欧美成人精品一区二区三区| 最好看的2019年中文视频| 一区二区三区在线播放欧美| 午夜精品一区二区三区在线播放| 成人免费网站在线观看| 日韩高清人体午夜| 国产精品久久激情| 国产精品高精视频免费| 久久人91精品久久久久久不卡| 91免费电影网站| 国产精品香蕉在线观看| 久久久久久成人精品| 欧美一二三视频| 日韩高清电影免费观看完整版| 欧美日韩精品在线| 亚洲综合色av| 亚洲欧美日韩区| 成人在线视频网| 26uuu另类亚洲欧美日本老年| 亚洲一区二区在线播放| 97超视频免费观看| 欧美日韩国产色| 欧美激情a在线| 亚洲欧美制服综合另类| 亚洲91精品在线观看| 亚洲免费一级电影| 欧美激情一区二区三级高清视频| 美日韩丰满少妇在线观看| 91美女片黄在线观| 91国内在线视频| 国产精品第一区| 日韩二区三区在线| 欧美日韩中国免费专区在线看| 日韩精品中文字幕在线| 欧美精品一区在线播放| 69**夜色精品国产69乱| 在线看国产精品| 欧美中文在线免费| 久久精品99无色码中文字幕| 欧美性猛交xxxx久久久| 国产精品久久久久久影视| 中文字幕亚洲欧美日韩在线不卡| 亚洲精品日韩丝袜精品| 欧美日韩在线视频一区| 国产精品人成电影在线观看| 日韩中文字幕免费看| 国产精品一区二区久久精品| 欧美成人精品三级在线观看| 国产精品免费久久久久影院| 日韩精品一区二区三区第95| 欧美在线视频播放| 日韩在线中文字幕| 国产综合久久久久久| 国产精品扒开腿爽爽爽视频| 欧美激情在线一区| 日韩高清电影免费观看完整| 国产欧美精品在线| 国产精品久久久久久影视| 久久天天躁狠狠躁夜夜爽蜜月| 欧美巨乳在线观看|