ADO 方式访问 Excel 文件的问题

来源:互联网 发布:js中gbk编码转换utf8 编辑:程序博客网 时间:2024/06/05 16:04

最近需要利用 ADO 的方式访问 Excel,其间遇到的问题很多,且把问题和解决方法列在这里。


1 发现在连接时报 Provider cannot be found 错误


结果采用 x64 进行编译可以正确执行,才领悟到原来没有安装 32 位的相关驱动啊。


2 import msado15.dll 的位置问题


X64 平台下分成32位和64位两个版本。


64位:

#import "C:\Program Files\Common Files\System\ADO\msado15.dll" no_namespace \    rename("EOF", "adoEOF") rename("BOF", "adoBOF")

32位:

#import "C:\Program Files (x86)\Common Files\System\ADO\msado15.dll" no_namespace \    rename("EOF", "adoEOF") rename("BOF", "adoBOF")



3 XLS 和 XLSX 新旧版本文件需要不同的连接字符串


XLS 对应的连接字符串:

connStr.Format("Provider='Microsoft.JET.OLEDB.4.0';Data Source=%s;Extended Properties=\"Excel 8.0;HDR=%s\"", filename, hdr);


XLS 对应的连接字符串则为:

connStr.Format("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=%s;Extended Properties=\"Excel 12.0 Xml;HDR=%s\"", filename, hdr); 


4 X64 模式的情况下,读取某条纪录的某列时需要传递LONG参数


最开始的代码:


CString str;str.Format("%d", pRec->Fields->GetCount());MessageBox(NULL, str, "Info", MB_OK);for (int j=0; j<pRec->Fields->GetCount(); ++j){_variant_t v = pRec->Fields->GetItem(j)->Value;MessageBox(NULL, (char*)(_bstr_t)v.bstrVal, "Info", MB_OK);}

结果列数正常,但就是报找不到列的错误,很是无奈。折腾了很久,知道后来改成如下的代码才通过。


for(long i = 0; i < pRec->Fields->GetCount(); ++i){_variant_t v = pRec->Fields->GetItem(i)->Value;}

_variant_t vv = pRec->Fields->GetItem(1L)->Value;


原创粉丝点击