Excel 2000~2003用:
const string szConnect = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source='{0}'; Extended Properties='Excel 8.0;'";
Excel 2007用:
const string szConnect = "Provider=Microsoft.ACE.OLEDB.12.0; Data Source={0}; Extended Properties='Excel 12.0 XML;'";
其中Extended Properties参数还可以添加HDR=YES/NO属性,当HDR=YES时将第一行记录当成表头(Columns)。
另外还有IMEX=0/1,这个属性意思是自动获取列的类型,比如某列下面的记录都是数值,那么这列的类型就自动匹配为double,否则就是字符串,也可以自动匹配为datetime日期时间类型。
当IMEX=1时,将只扫描前8项记录(8这个默认值可以在注册表[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Jet\4.0\Engines\Excel\TypeGuessRows]修改),但是这样速度虽然比较快,但有可能不能准确获取该列的真正类型。比如说一个数据表它的第3列数据前8项是1,2,3,4,5,6,7,8,恰好后面的几项是9,A,B,C,D,...这样获取到的第三列的类型就误判为double,而9后面字母将变为空值(null)返回。
如果要扫描所有的行,请设置为IMEX=0。
Extended Properties参数中可用的引擎可以在注册表[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Office\12.0\Access Connectivity Engine\ISAM Formats]下面查到。