C# 使用 OleDbConnection 連接讀取Excel的方法
Connection類有四種:SqlConnection,OleDbConnection,OdbcConnection和OracleConnection。
(1)Sqlconnetcion類的對(duì)象連接是SQL Server數(shù)據(jù)庫(kù);
(2)OracleConnection類的對(duì)象連接Oracle數(shù)據(jù)庫(kù);
(3)OleDbConneetion連接支持OLEDB的數(shù)據(jù)庫(kù),如Access;
(4)OdbcConnection類的對(duì)象連接支持ODBC的數(shù)據(jù)庫(kù)。
與數(shù)據(jù)庫(kù)的所有通訊都是通過(guò)Connection對(duì)象來(lái)完成的。
OleDbConnection類的常用屬性及其說(shuō)明
屬性 說(shuō)明
ConnectionString 獲取或設(shè)置用于打開數(shù)據(jù)庫(kù)的字符串
ConnectionTimeOut 獲取在嘗試建立連接時(shí)終止嘗試并生成錯(cuò)誤之前所等待的時(shí)間
Database 獲取當(dāng)前數(shù)據(jù)庫(kù)或連接打開后要使用的數(shù)據(jù)庫(kù)名稱
DataSource 獲取數(shù)據(jù)源的服務(wù)器名或文件名
Provider 獲取在連接字符串的“Provider = ” 子句中指定的OLEDB提供程序的名稱
State 獲取連接的當(dāng)前狀態(tài)
OleDbConnection類的常用方法如下表所示:
Open 使用ConnectionString所指定的屬性設(shè)置打開數(shù)據(jù)庫(kù)連接
Close 關(guān)閉與數(shù)據(jù)庫(kù)的連接,這是關(guān)閉任何打開連接的首選方法
CreateCommand 創(chuàng)建并返回一個(gè)與OleDbConnection關(guān)聯(lián)的OleDbCommand對(duì)象
ChangeDatabase 為打開的OleDbConnection更改當(dāng)前數(shù)據(jù)庫(kù)
下面用c#寫了個(gè)控制臺(tái)應(yīng)用實(shí)現(xiàn)使用 OleDbConnection 讀取Excel(支持.xls與.xlsx文件)
class Program
{
//函數(shù)用來(lái)讀取一個(gè)excel文件到DataSet集中
public static DataSet ExcelToDataSet(string filename, string tableName)
{
//獲取文件擴(kuò)展名
string strExtension = System.IO.Path.GetExtension(filename);
OleDbConnection myConn = null;
switch (strExtension)
{
case ".xls":
myConn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filename + ";" + "Extended Properties=\"Excel 8.0;HDR=yes;IMEX=1;\"");
break;
case ".xlsx":
myConn = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filename + ";" + "Extended Properties=\"Excel 12.0;HDR=yes;IMEX=1;\"");
//此連接可以操作.xls與.xlsx文件 (支持Excel2003 和 Excel2007 的連接字符串)
//"HDR=yes;"是說(shuō)Excel文件的第一行是列名而不是數(shù),"HDR=No;"正好與前面的相反。"IMEX=1 "如果列中的數(shù)據(jù)類型不一致,使用"IMEX=1"可必免數(shù)據(jù)類型沖突。
break;
default:
myConn = null;
break;
}
if (myConn == null)
{
return null;
}
string strCom = " SELECT * FROM ["+ tableName + "$]";
myConn.Open();
//獲取Excel指定Sheet表中的信息
OleDbDataAdapter myCommand = new OleDbDataAdapter(strCom, myConn);
DataSet ds;
ds = new DataSet();
myCommand.Fill(ds, tableName);
myConn.Close();
return ds;
}
static void Main(string[] args)
{
var tablename = "sheet1";
//括號(hào)中為表格地址
DataSet ds = ExcelToDataSet("D:\\get.xls", tablename);
for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
{
string str = ds.Tables[tablename].Rows[i]["價(jià)格"].ToString(); //Rows[i]["col1"]表示i行"col1"字段
Console.WriteLine(str);
}
Console.WriteLine("正確執(zhí)行...");
Console.ReadKey();
}
}
記得在D盤先新建excel文件,如下

到此這篇關(guān)于C# 使用 OleDbConnection 連接讀取Excel的方法的文章就介紹到這了,更多相關(guān)C# 讀取Excel內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C#使用String和StringBuilder運(yùn)行速度測(cè)試及各自常用方法簡(jiǎn)介
今天小編就為大家分享一篇關(guān)于C#使用String和StringBuilder運(yùn)行速度測(cè)試及各自常用方法簡(jiǎn)介,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-10-10
C#實(shí)現(xiàn)Json轉(zhuǎn)Unicode的方法
這篇文章主要介紹了C#實(shí)現(xiàn)Json轉(zhuǎn)Unicode的方法,可實(shí)現(xiàn)輸入為帶有json格式的文本,輸出正常文本的功能,需要的朋友可以參考下2014-09-09
C#調(diào)用HTTP POST請(qǐng)求上傳圖片的示例代碼
現(xiàn)在很多B/S系統(tǒng)的開發(fā)都是通過(guò)API方式來(lái)進(jìn)行的,一般服務(wù)端會(huì)開放一個(gè)API接口,客戶端調(diào)用API接口來(lái)實(shí)現(xiàn)圖片或文件上傳的功能,感興趣的可以了解一下2021-05-05
word ppt excel文檔轉(zhuǎn)換成pdf的C#實(shí)現(xiàn)代碼
這篇文章主要介紹了word ppt excel文檔轉(zhuǎn)換成pdf的C#實(shí)現(xiàn)代碼,有需要的朋友可以參考一下2014-01-01

