导入excel错误:外部表不是预期的格式 解决方案(Oledb)

-----转载:http://blog.csdn.net/zhou349398998/article/details/8740424

环境:win7+iis7+Office2007 

在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(); 
        }

 

文章来源(http://www.cnblogs.com/kingkongv/archive/2012/08/26/2657436.html

 

转载于:https://www.cnblogs.com/tianma3798/p/3496882.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值