excel錯誤:外部表不是預期的格式 錯誤

環境:win7+iis7+Office2007html

在asp.net網站中導出Excel文件後,再把文件導入到數據庫中。 讀取Excel文件時,打開鏈接出錯。數據庫

錯誤爲:外部表不是預期的格式asp.net

解決:檢查了一下,導出的Excel是標準文件不是html,沒錯,Excel文件正常。less

調試代碼,建立鏈接對象oleDbConnection也正常,但在conn.Open()打開連接時出錯。ide

仔細看了下連接字符串,檢查出了錯誤,Excel版本問題,Exce鏈接字符串版本是office2003的 ,更改成Excel2007版本則正常導入。網站

總結規則以下:this

複製代碼
using System.Data.OleDb;
using System.Data;

 public void ReadExcelFiless()
        {
            //string strConn = "Provider=Microsoft.Jet.OleDb.4.0;" + "data source=" + Server.MapPath("ExcelFiles/MyExcelFile.xls") + ";Extended Properties='Excel 8.0; HDR=Yes; IMEX=1'"; //此鏈接只能操做Excel2007以前(.xls)文件
            string strConn = "Provider=Microsoft.Ace.OleDb.12.0;" + "data source=" + Server.MapPath("ExcelFiles/Mydata2007.xlsx") + ";Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'"; //此鏈接能夠操做.xls與.xlsx文件 (支持Excel2003 和 Excel2007 的鏈接字符串)
//備註: "HDR=yes;"是說Excel文件的第一行是列名而不是數據,"HDR=No;"正好與前面的相反。 // "IMEX=1 "若是列中的數據類型不一致,使用"IMEX=1"可必免數據類型衝突。 

            OleDbConnection conn = new OleDbConnection(strConn);
            OleDbDataAdapter adp = new OleDbDataAdapter("Select * from [Sheet1$]", conn);
            DataSet ds = new DataSet();
            adp.Fill(ds, "Book1");
            this.GridView1.DataSource = ds.Tables["Book1"].DefaultView;
            this.GridView1.DataBind(); 
        }
複製代碼
相關文章
相關標籤/搜索