百度一下可以了解到,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。
(上面的来自:http://blog.csdn.net/laoyebin/archive/2009/11/29/4902313.aspx)
//2007(Microsoft.ACE.OLEDB.12.0)
string mystring = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + path + ";Extended Properties=''''Excel 8.0;HDR=Yes;IMEX=1;''''";
//2003(Microsoft.Jet.Oledb.4.0)
string mystring = "Provider=Microsoft.Jet.Oledb.4.0;Data Source=" + path + ";Extended Properties=''''Excel 8.0;HDR=Yes;IMEX=1;''''";