C#读取excel出错提示外部表不是预期的格式

来源:互联网 发布:手机淘宝联盟链接转换 编辑:程序博客网 时间:2024/05/22 16:48

很多人换了2007/2010后,问的最多的问题之一是2003里最经典的ADO中的“provider=Microsoft.Jet.OLEDB.4.0”这句怎么不能用了。

百度一下可以了解到,Microsoft.Jet.OLEDB.4.0是MicrosoftJet引擎,这适用于2003版本(2003之前的我没装,所以也不知道能向下适应到哪个版本),而在2007中,微软对其旗下 Access与 Excel 的主要文件格式进行修改,并且重命名为 .accdb(Access 2007 数据库文件)与 .xlsx(Excel2007 文件),因此未被 Microsoft Jet 引擎所支持,不过微软也很快的提出了Microsoft Office 2007 Desktop Drivers: Data ConnectivityComponents 来支持,目前的解决方法就是把连接字符串中的数据提供者改为Microsoft.ACE.OLEDB.12.0。

解决方案1:

//2003(Microsoft.Jet.Oledb.4.0)
string strConn =string.Format("Provider=Microsoft.Jet.OLEDB.4.0;DataSource={0};Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'",excelFilePath);

//2007(Microsoft.ACE.OLEDB.12.0)
string strConn =string.Format("Provider=Microsoft.ACE.OLEDB.12.0;DataSource={0};Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'",excelFilePath);

//2010(Microsoft.ACE.OLEDB.12.0)
string strConn =string.Format("Provider=Microsoft.ACE.OLEDB.12.0;DataSource={0};Extended Properties='Excel 12.0;HDR=Yes;IMEX=1;'",excelFilePath);

解决方案2:

用记事本打开你的excel文件,看看显示是否为乱码。
若是乱码,我这边测试是不会提示这个错误的,可以成功导入。

若是html代码,则表示你的excel文件格式不是标准的excel格式,才会提示“外部表不是预期的格式”的错误;

总结:如果格式不正确,则通过excel软件另存为标准的2003版本的格式

0 0