国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

asp.net讀取excel文件的三種方法示例

2024-07-10 12:43:33
字體:
來源:轉載
供稿:網友

方法一:采用OleDB讀取Excel文件

把Excel文件當做一個數據源來進行數據的讀取操作,實例如下:
代碼如下:
public DataSet ExcelToDS(string Path)  
{  
string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" +"Data Source="+ Path +";"+"Extended Properties=Excel 8.0;";  
OleDbConnection conn = new OleDbConnection(strConn);  
conn.Open(); 
string strExcel = "";  
OleDbDataAdapter myCommand = null;  
DataSet ds = null;  
strExcel="select * from [sheet1$]";  
myCommand = new OleDbDataAdapter(strExcel, strConn);  
ds = new DataSet();  
myCommand.Fill(ds,"table1");  
return ds;  
}

對于Excel中的表即sheet([sheet1$])如果不是固定的可以使用下面的方法得到

代碼如下:
string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" +"Data Source="+ Path +";"+"Extended Properties=Excel 8.0;";
OleDbConnection conn = new OleDbConnection(strConn);
DataTable schemaTable = objConn.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables,null);
string tableName=schemaTable.Rows[0][2].ToString().Trim();

另外:也可進行寫入Excel文件,實例如下:

代碼如下:
public void DSToExcel(string Path,DataSet oldds)  
{  
//先得到匯總Excel的DataSet 主要目的是獲得Excel在DataSet中的結構  
string strCon = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source ="+path1+";Extended Properties=Excel 8.0" ;  
OleDbConnection myConn = new OleDbConnection(strCon) ;  
string strCom="select * from [Sheet1$]";  
myConn.Open ( ) ;  
OleDbDataAdapter myCommand = new OleDbDataAdapter ( strCom, myConn ) ;  
system.Data.OleDb.OleDbCommandBuilder builder=new OleDbCommandBuilder(myCommand);  
//QuotePrefix和QuoteSuffix主要是對builder生成InsertComment命令時使用。  
builder.QuotePrefix="["; //獲取insert語句中保留字符(起始位置)  
builder.QuoteSuffix="]"; //獲取insert語句中保留字符(結束位置)  
DataSet newds=new DataSet();  
myCommand.Fill(newds ,"Table1") ;  
for(int i=0;i<oldds.Tables[0].Rows.Count;i++)  
{  
//在這里不能使用ImportRow方法將一行導入到news中,  
//因為ImportRow將保留原來DataRow的所有設置(DataRowState狀態不變)。  
//在使用ImportRow后newds內有值,但不能更新到Excel中因為所有導入行的DataRowState!=Added  
DataRow nrow=aDataSet.Tables["Table1"].NewRow();  
for(int j=0;j<newds.Tables[0].Columns.Count;j++)  
{  
nrow[j]=oldds.Tables[0].Rows[i][j];  
}  
newds.Tables["Table1"].Rows.Add(nrow);  
}  

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 麻江县| 柘荣县| 思南县| 威远县| 衡阳市| 出国| 登封市| 株洲县| 若尔盖县| 泾阳县| 磐安县| 夹江县| 灵台县| 临沭县| 德清县| 察雅县| 揭东县| 连江县| 定边县| 镇安县| 上饶县| 西乡县| 襄汾县| 凤庆县| 定陶县| 开化县| 万盛区| 黔东| 酒泉市| 桓台县| 防城港市| 麻江县| 花莲市| 澎湖县| 友谊县| 蒲江县| 喜德县| 永德县| 黔西县| 金塔县| 南汇区|