ASP.NET讀取Excel文件方法一:采用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 ) ;
ystem.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);
新聞熱點
疑難解答
圖片精選