C# 导入EXCEL 报错外部表不是预期的格式错误
我用的是vs2015,wpf程序,没有语法错误,代码针对的是excel2003,而我的是excel2003,文件名是stu.xls,一切都吻合,完全不知道为何报错priv...
我用的是vs2015,wpf程序,没有语法错误,代码针对的是excel2003,而我的是excel2003,文件名是stu.xls,一切都吻合,完全不知道为何报错 private void button_leadIn_Click(object sender, RoutedEventArgs e) { OpenFileDialog ofd = new OpenFileDialog(); ofd.Filter = "Microsoft Excel files(*.xls)|*.xls;*.xlsx";//过滤一下,只要表格格式的 ofd.InitialDirectory = "c:\\"; ofd.RestoreDirectory = true; ofd.FilterIndex = 1; ofd.AddExtension = true; ofd.CheckFileExists = true; ofd.CheckPathExists = true; if (ofd.ShowDialog() == true) { string DBString = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source =" + ofd.FileName + ";Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'";//这是excel2003的读取 OleDbConnection con = new OleDbConnection(DBString); con.Open(); DataTable datatable = con.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null); //获取表单,原始的是:Sheet1,Sheet2,Sheet3 for (int i = 0; i < datatable.Rows.Count; i++) { //获取表单的名字 String sheet = datatable.Rows[i][2].ToString().Trim(); OleDbDataAdapter ole = new OleDbDataAdapter("select * from [" + sheet + "]", con); DataSet ds = new DataSet(); ole.Fill(ds); //输出表格里面的内容,我这里就两列数据,如果数据列数不确定就需要写循环了:Rows.Count foreach (DataRow col in ds.Tables[0].Rows) { Console.WriteLine(col[0].ToString()); Console.WriteLine(col[1].ToString()); } } con.Close(); }
后缀.xls,excel2003,还出错,真是奇了怪了 展开
后缀.xls,excel2003,还出错,真是奇了怪了 展开
1个回答
展开全部
在asp.net网站中导出Excel文件后,再把文件导入到数据库中。 读取Excel文件时,打开连接出错。
错误为:外部表不是预期的格式
解决:检查了一下,导出的Excel是标准文件不是html,没错,Excel文件正常。
调试代码,创建连接对象oleDbConnection也正常,但在conn.Open()打开链接时出错。
仔细看了下链接字符串,检查出了错误,Excel版本问题,Exce连接字符串版本是office2003的 ,更改为Excel2007版本则正常导入。
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(); }
错误为:外部表不是预期的格式
解决:检查了一下,导出的Excel是标准文件不是html,没错,Excel文件正常。
调试代码,创建连接对象oleDbConnection也正常,但在conn.Open()打开链接时出错。
仔细看了下链接字符串,检查出了错误,Excel版本问题,Exce连接字符串版本是office2003的 ,更改为Excel2007版本则正常导入。
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(); }
追问
这么说要换成2007.
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询