濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > ASP.NET(C#) 讀取EXCEL另加解決日期問(wèn)題的方法分享

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

熱門標(biāo)簽:外呼系統(tǒng)費(fèi)用一年 寧波自動(dòng)外呼系統(tǒng)代理 辦理400電話證件 世紀(jì)佳緣地圖標(biāo)注怎么去掉 外呼系統(tǒng)代理品牌 十堰正規(guī)電銷機(jī)器人系統(tǒng) 手機(jī)地圖標(biāo)注如何刪除 怎么給超市做地圖標(biāo)注入駐店 巫師3為什么地圖標(biāo)注的財(cái)寶沒(méi)有

使用OLEDB可以對(duì)excel文件進(jìn)行讀取,我們只要把該excel文件作為數(shù)據(jù)源即可。

一 在D盤創(chuàng)建excel文件test.xls:

二 將工作表Sheet1的內(nèi)容讀取到DataSet

復(fù)制代碼 代碼如下:

  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為:

從圖中可以看出excel文件中的第一行變成了DataSet中的列名,這正是系統(tǒng)的默認(rèn)設(shè)置。

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

復(fù)制代碼 代碼如下:

  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);

  結(jié)果也許會(huì)讓你有點(diǎn)想不到:

第一行的第一列和第三列都變成空的了,這是因?yàn)橄到y(tǒng)把第一列識(shí)別成了數(shù)字,把第三列識(shí)別成了日期,

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

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

復(fù)制代碼 代碼如下:

  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);

  結(jié)果又會(huì)如何呢?

是不是再次出乎你的意料,第三行的日期怎么變成數(shù)字了,其實(shí)excel在轉(zhuǎn)換格式的時(shí)候就自動(dòng)把日期變成數(shù)字了,

那這個(gè)數(shù)字是怎么來(lái)的呢 ? 如果你把日期改成1900年1月1日,那么你可以看到他的轉(zhuǎn)換結(jié)果是1,以此類推,39902是哪一天就明白了吧。

這里解決辦法:

方法一:

復(fù)制代碼 代碼如下:

  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;
      }


方法二:
復(fù)制代碼 代碼如下:

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

五 也許你并不想讀取整個(gè)excel的內(nèi)容

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

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

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

我們可以通過(guò)索引來(lái)獲取指定工作表的名字,以下方法可以用來(lái)獲取工作表名稱的數(shù)組:

復(fù)制代碼 代碼如下:

  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的時(shí)候并不是全都會(huì)作為字符串來(lái)處理,根據(jù)系統(tǒng)的默認(rèn)設(shè)置,通常如果前8行有字符串,則該列會(huì)作為字符串來(lái)處理,如果全都為數(shù)字,則該列為數(shù)字列,日期也是一樣。

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

無(wú)法讀取EXCEL中的數(shù)據(jù)單元格。有數(shù)據(jù),但是讀出來(lái)全是空值。

解決方法:

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

注:

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

“IMEX=1;”通知驅(qū)動(dòng)程

序始終將“互混”數(shù)據(jù)列作為文本讀取。

兩者必須一起使用。

本以為這樣就OK了。但在實(shí)際使用過(guò)程中,這樣設(shè)置還是不行,查閱了不少資料才發(fā)現(xiàn),原來(lái)還有一個(gè)注冊(cè)表里的信息需要修改,這樣帶能讓excel不再使用前8行的內(nèi)容來(lái)確定該列的類型。

注冊(cè)表修改內(nèi)容如下:

在HKEY_LOCAL_MACHINE\Software\Microsoft\Jet\4.0\Engines\Excel有一個(gè)TypeGuessRows值,預(yù)設(shè)是8,表示會(huì)先讀取前8列來(lái)決定每一個(gè)欄位的型態(tài),所以如果前8列的資料都是數(shù)字,到了第9列以后出現(xiàn)的文字資料都會(huì)變成null,所以如果要解決這個(gè)問(wèn)題,只要把TypeGuessRows機(jī)碼值改成0,就可以解這個(gè)問(wèn)題了。

您可能感興趣的文章:
  • asp.net下日期加減的方法
  • ASP.NET如何獲取兩個(gè)日期之間的天數(shù)
  • asp.net 時(shí)間類 一周的周一和周末的日期
  • asp.net 日期函數(shù) 某月的第一天和最后一天的日期
  • Asp.net 時(shí)間操作基類(支持短日期,長(zhǎng)日期,時(shí)間差)
  • 基于Asp.net與Javascript控制的日期控件
  • asp.net 2個(gè)日期之間的整月數(shù)的算法
  • asp.net下定制日期輸出格式的代碼
  • ASP.NET Calendar日歷(日期)控件使用方法
  • 基于ASP.NET實(shí)現(xiàn)日期轉(zhuǎn)為大寫的漢字

標(biāo)簽:牡丹江 嘉興 天門 山西 泰州 景德鎮(zhèn) 通遼

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ASP.NET(C#) 讀取EXCEL另加解決日期問(wèn)題的方法分享》,本文關(guān)鍵詞  ASP.NET,讀取,EXCEL,另加,解決,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ASP.NET(C#) 讀取EXCEL另加解決日期問(wèn)題的方法分享》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于ASP.NET(C#) 讀取EXCEL另加解決日期問(wèn)題的方法分享的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    迭部县| 清水河县| 彰化县| 林周县| 宜君县| 乡宁县| 库尔勒市| 曲水县| 罗山县| 肥乡县| 江永县| 平和县| 泾源县| 蚌埠市| 布尔津县| 从化市| 阜城县| 和平县| 甘肃省| 遂昌县| 刚察县| 大厂| 金秀| 南郑县| 保德县| 南康市| 酒泉市| 民勤县| 曲阳县| 廊坊市| 新和县| 祁阳县| 苏尼特左旗| 九龙坡区| 铁岭县| 崇文区| 黄梅县| 连山| 徐水县| 香河县| 扶沟县|