怎样才能在VC程序里使用GetExcelDriver函数? 需要添加什么头文件?或者类?

 我来答
bhtzu
2013-03-04 · TA获得超过1.1万个赞
知道大有可为答主
回答量:8088
采纳率:85%
帮助的人:4228万
展开全部
这个是自定义函数,不是系统自带函数,所以。。你加什么头文件都没用。

自定义函数实现如下:
CString GetExcelDriver()
{
char szBuf[2001];
WORD cbBufMax = 2000;
WORD cbBufOut;
char *pszBuf = szBuf;
CString sDriver;

// 获取已安装驱动的名称(涵数在odbcinst.h里)
if (!SQLGetInstalledDrivers(szBuf, cbBufMax, &cbBufOut))
return "";

// 检索已安装的驱动是否有Excel...
do
{
if (strstr(pszBuf, "Excel") != 0)
{
//发现 !
sDriver = CString(pszBuf);
break;
}
pszBuf = strchr(pszBuf, '\0') + 1;
}
while (pszBuf[1] != '\0');

return sDriver;
}
来自:求助得到的回答
统了个强
2014-06-03 · TA获得超过417个赞
知道小有建树答主
回答量:153
采纳率:50%
帮助的人:44.1万
展开全部
上面说的那个是不错,我这里再给个UNICODER下的代码:

// 检索是否安装有Excel驱动 "Microsoft Excel Driver (*.xls)"
CString GetExcelDriver()
{
TCHAR szBuf[2056];
WORD cbBufMax = 2000;
WORD cbBufOut;
TCHAR *pszBuf = szBuf;
CString sDriver;

// 获取已安装驱动的名称(涵数在odbcinst.h里)
if (!SQLGetInstalledDrivers(szBuf, cbBufMax, &cbBufOut))
return L"";
// 检索已安装的驱动是否有Excel...
do
{
if (wcsstr(pszBuf, _T("Excel")) != 0)
{
//发现 !
sDriver = pszBuf;
//break;
}
pszBuf = wcschr(pszBuf, '\0') + 1;
}
while (pszBuf[1] != '\0');
return sDriver;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式