導(dǎo)入excel錯(cuò)誤:外部表不是預(yù)期的格式解決方案
環(huán)境:win7 iis7 Office2007
在asp.net網(wǎng)站中導(dǎo)出Excel文件后,再把文件導(dǎo)入到數(shù)據(jù)庫(kù)中。 讀取Excel文件時(shí),打開(kāi)連接出錯(cuò)。
錯(cuò)誤為:外部表不是預(yù)期的格式
解決:檢查了一下,導(dǎo)出的Excel是標(biāo)準(zhǔn)文件不是html,沒(méi)錯(cuò),Excel文件正常。
調(diào)試代碼,創(chuàng)建連接對(duì)象oleDbConnection也正常,但在conn.Open()打開(kāi)鏈接時(shí)出錯(cuò)。
仔細(xì)看了下鏈接字符串,檢查出了錯(cuò)誤,Excel版本問(wèn)題,Exce連接字符串版本是office2003的 ,更改為Excel2007版本則正常導(dǎo)入。
總結(jié)規(guī)則如下:
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;"是說(shuō)Excel文件的第一行是列名而不是數(shù)據(jù),"HDR=No;"正好與前面的相反。 // "IMEX=1 "如果列中的數(shù)據(jù)類(lèi)型不一致,使用"IMEX=1"可必免數(shù)據(jù)類(lèi)型沖突。 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(); }
原文鏈接:.Net導(dǎo)入excel錯(cuò)誤,外部表不是預(yù)期的格式解決方案