ASP.NET(C#) 讀取EXCEL另加解決日期問(wèn)題的方法分享
使用OLEDB可以對(duì)excel文件進(jìn)行讀取,我們只要把該excel文件作為數(shù)據(jù)源即可。
一 在D盤(pán)創(chuàng)建excel文件test.xls:

二 將工作表Sheet1的內(nèi)容讀取到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為:
從圖中可以看出excel文件中的第一行變成了DataSet中的列名,這正是系統(tǒng)的默認(rèn)設(shè)置。
三 如果想把第一行也作為數(shù)據(jù)行,那我們可以給連接字符串添加一個(gè)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);
結(jié)果也許會(huì)讓你有點(diǎn)想不到:

第一行的第一列和第三列都變成空的了,這是因?yàn)橄到y(tǒng)把第一列識(shí)別成了數(shù)字,把第三列識(shí)別成了日期,
而第一行的數(shù)據(jù)不符合格式的要求,所以就變成空的了。
四 我們還可以把所有列都做為字符串來(lái)讀取,只要添加屬性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);
結(jié)果又會(huì)如何呢?

是不是再次出乎你的意料,第三行的日期怎么變成數(shù)字了,其實(shí)excel在轉(zhuǎn)換格式的時(shí)候就自動(dòng)把日期變成數(shù)字了,
那這個(gè)數(shù)字是怎么來(lái)的呢 ? 如果你把日期改成1900年1月1日,那么你可以看到他的轉(zhuǎn)換結(jié)果是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");
五 也許你并不想讀取整個(gè)excel的內(nèi)容
如果只想讀取前兩列可以用:select * from [Sheet1$A:B]
如果只想讀取A1到B2的內(nèi)容,就用:select * from [Sheet1$A1:B2]
六 如果不知道工作表的名字或名字被人為修改了該怎么辦呢?
我們可以通過(guò)索引來(lái)獲取指定工作表的名字,以下方法可以用來(lái)獲取工作表名稱的數(shù)組:
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)題了。
相關(guān)文章
ASP.NET Core使用Log4net實(shí)現(xiàn)日志記錄功能
這篇文章介紹了ASP.NET Core使用Log4net實(shí)現(xiàn)日志記錄功能的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
.NET?9?new?features-Microsoft.ML.Tokenizers?庫(kù)(文本標(biāo)記化功能)
文章介紹了.NET9中引入的Microsoft.ML.Tokenizers庫(kù),這是一個(gè)強(qiáng)大的文本標(biāo)記化工具,支持多種標(biāo)記化算法,適用于自然語(yǔ)言處理任務(wù),庫(kù)主要包含Tokenizer、Model、Bpe等類,并提供了詳細(xì)的代碼示例,感興趣的朋友一起看看吧2025-01-01
ASP.NET URL偽靜態(tài)重寫(xiě)實(shí)現(xiàn)方法
ASP.NET下為靜態(tài)的實(shí)現(xiàn)方法。2009-12-12
C#開(kāi)發(fā)微信 二維碼鼠標(biāo)滑動(dòng) 圖像顯示隱藏效果(推薦)
客戶端微信在二維碼狀態(tài)下,鼠標(biāo)滑過(guò),會(huì)有一張手機(jī)的圖片滑動(dòng)滑出,從隱藏到顯示,從顯示到隱藏。效果非常棒,本文思路介紹明確,感興趣的朋友一起看看吧2016-11-11
微信公眾平臺(tái)開(kāi)發(fā)之地理位置.Net代碼解析
這篇文章主要為大家詳細(xì)解析了微信公眾平臺(tái)開(kāi)發(fā)之地理位置.Net代碼,感興趣的小伙伴們可以參考一下2016-06-06
asp.net上傳execl文件后,在頁(yè)面上加載顯示(示例代碼)
本篇文章主要是對(duì)asp.net上傳execl文件后,在頁(yè)面上加載顯示(示例代碼)進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02

