WinForm导入Excel2007报外部表不是预期的格式

时间:2022-12-18 20:31:46
 我是用的oledb去获取excel内的数据
连接串如下
string strConn = string.Format("Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties='Excel 12.0;HDR=NO;';Persist Security Info=False", FileName);

不知道为什么一会能成功调用  一会又不能 很郁闷 之前也没搞过这个Winform 所以不太明白

 希望大神门帮个忙

8 个解决方案

#1


是不是有合并格啊

#2


引用 1 楼  的回复:
是不是有合并格啊

没有 啊 我刚新建了一个表格 绝对没有 也是报这个错误  不过还不是一直都报 偶尔还是能导入的。。。这让我很纳闷

#3


错误原因1: 
由于Excel 97-2003的连接格式与Excel 2007 的 不同造成。
解决方案1:

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

百度一下可以了解到,Microsoft.Jet.OLEDB.4.0是Microsoft Jet引擎,这适用于2003版本(2003之前的我没装,所以也不知道能向下适应到哪个版本),而在2007中,微软对其旗下 Access 与 Excel 的主要文件格式进行修改,并且重命名为 .accdb(Access 2007 数据库文件)与 .xlsx(Excel 2007 文件),因此未被 Microsoft Jet 引擎所支持,不过微软也很快的提出了 Microsoft Office 2007 Desktop Drivers: Data Connectivity Components 来支持,目前的解决方法就是把连接字符串中的数据提供者改为 Microsoft.ACE.OLEDB.12.0。
--------------------------------------------------------------------------------------------------------------
//2003(Microsoft.Jet.Oledb.4.0)
string strConn = string.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={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;Data Source={0};Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'", excelFilePath);

解决方案2:
用记事本打开你的excel文件,看看显示是否为乱码。
若是乱码,我这边测试是不会提示这个错误的,可以成功导入。
若是html代码,则表示你的excel文件格式不是标准的excel格式,才会提示“外部表不是预期的格式”的错误;
总结:如果格式不正确,则通过excel软件另存为标准的2003版本的格式

#4


引用 3 楼  的回复:
错误原因1: 
由于Excel 97-2003的连接格式与Excel 2007 的 不同造成。
解决方案1:

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

百度一下可以了解到,Microsoft.Jet.OLEDB.4.0是Microsoft Jet引擎,这适用于200……

这个没用 凡是百度上能搜到的 方法我都试过了 结果当然是不行了

#5


你的xls文件必须是excel里面创建的,不能说通过其他工具导出成的,如果网页导出的,这些都是假的xls文件

#6


引用 5 楼  的回复:
你的xls文件必须是excel里面创建的,不能说通过其他工具导出成的,如果网页导出的,这些都是假的xls文件

还真不是  那个xlsx是真的 现在更诡异的情况出现了 xlsx偶尔都打开 但是只要报一次这个异常“外部表不是预期的格式” 就很长时间都报

#7


引用 6 楼  的回复:
引用 5 楼  的回复:

你的xls文件必须是excel里面创建的,不能说通过其他工具导出成的,如果网页导出的,这些都是假的xls文件

还真不是  那个xlsx是真的 现在更诡异的情况出现了 xlsx偶尔都打开 但是只要报一次这个异常“外部表不是预期的格式” 就很长时间都报

如果你排除了上面提到的错误的话,那就是你Office本身的问题了,你换台机器上尝试下排除下这个可能。

#8


同问  用了以上前辈的方法 还是没搞定,我的问题 就是  要导入的excel 的名字有时不是 ”sheet1“这种默认的名字 就会报这个错误。

#1


是不是有合并格啊

#2


引用 1 楼  的回复:
是不是有合并格啊

没有 啊 我刚新建了一个表格 绝对没有 也是报这个错误  不过还不是一直都报 偶尔还是能导入的。。。这让我很纳闷

#3


错误原因1: 
由于Excel 97-2003的连接格式与Excel 2007 的 不同造成。
解决方案1:

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

百度一下可以了解到,Microsoft.Jet.OLEDB.4.0是Microsoft Jet引擎,这适用于2003版本(2003之前的我没装,所以也不知道能向下适应到哪个版本),而在2007中,微软对其旗下 Access 与 Excel 的主要文件格式进行修改,并且重命名为 .accdb(Access 2007 数据库文件)与 .xlsx(Excel 2007 文件),因此未被 Microsoft Jet 引擎所支持,不过微软也很快的提出了 Microsoft Office 2007 Desktop Drivers: Data Connectivity Components 来支持,目前的解决方法就是把连接字符串中的数据提供者改为 Microsoft.ACE.OLEDB.12.0。
--------------------------------------------------------------------------------------------------------------
//2003(Microsoft.Jet.Oledb.4.0)
string strConn = string.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={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;Data Source={0};Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'", excelFilePath);

解决方案2:
用记事本打开你的excel文件,看看显示是否为乱码。
若是乱码,我这边测试是不会提示这个错误的,可以成功导入。
若是html代码,则表示你的excel文件格式不是标准的excel格式,才会提示“外部表不是预期的格式”的错误;
总结:如果格式不正确,则通过excel软件另存为标准的2003版本的格式

#4


引用 3 楼  的回复:
错误原因1: 
由于Excel 97-2003的连接格式与Excel 2007 的 不同造成。
解决方案1:

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

百度一下可以了解到,Microsoft.Jet.OLEDB.4.0是Microsoft Jet引擎,这适用于200……

这个没用 凡是百度上能搜到的 方法我都试过了 结果当然是不行了

#5


你的xls文件必须是excel里面创建的,不能说通过其他工具导出成的,如果网页导出的,这些都是假的xls文件

#6


引用 5 楼  的回复:
你的xls文件必须是excel里面创建的,不能说通过其他工具导出成的,如果网页导出的,这些都是假的xls文件

还真不是  那个xlsx是真的 现在更诡异的情况出现了 xlsx偶尔都打开 但是只要报一次这个异常“外部表不是预期的格式” 就很长时间都报

#7


引用 6 楼  的回复:
引用 5 楼  的回复:

你的xls文件必须是excel里面创建的,不能说通过其他工具导出成的,如果网页导出的,这些都是假的xls文件

还真不是  那个xlsx是真的 现在更诡异的情况出现了 xlsx偶尔都打开 但是只要报一次这个异常“外部表不是预期的格式” 就很长时间都报

如果你排除了上面提到的错误的话,那就是你Office本身的问题了,你换台机器上尝试下排除下这个可能。

#8


同问  用了以上前辈的方法 还是没搞定,我的问题 就是  要导入的excel 的名字有时不是 ”sheet1“这种默认的名字 就会报这个错误。