QT 使用QAxObject 新建excel 出现的问题

Gskygao 2013-05-31 10:24:20
代码:

#include <QAxObject>

main()
{
QAxObject excel("Excel.Application");
excel.setProperty("Visible", false);
QAxObject *workbooks = excel.querySubObject("WorkBooks");
QAxObject *workbook;

...........
.....
}

提示的错误:
CoCreateInstance failure <CoInitialize has not been called.>
QAxBase::setControl: requested control Excel.Application could not be instantiated
QAxBase::dynamicCallHelper: Object is not initialized, or initialization failed

看到有人说要安装Office, 我已经装了Office,还是会出现这个错误。

请高手帮忙
...全文
2502 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
guixf0101 2015-07-22
  • 打赏
  • 举报
回复
楼主最后是怎么解决的,我也遇到了这个问题,还没有找到答案,求指教
frank_llw 2015-01-20
  • 打赏
  • 举报
回复
与楼上问题同问
kongxian2007 2014-09-22
  • 打赏
  • 举报
回复
你好 按你的方法试了一下,报了错误 QAxBase::dynamicCallHelper: Object does not support automation,COM Object不支持自动化调用,请问该如何解决啊 ,你有没有遇到
wjq8771180 2014-09-10
  • 打赏
  • 举报
回复
加了哪三行代码啊,为什么我是有的电脑可以,有的电脑就会报这个错误
dbzhang800 2013-06-03
  • 打赏
  • 举报
回复
对,COM/ActiveX 编程必须 CoInitialize ! 在Qt下,由于 QApplication 中需要使用系统 粘贴板,已经调用过 CoInitialize 了,所以很容易被忽略这个问题。
Gskygao 2013-06-03
  • 打赏
  • 举报
回复
非常感谢两位。 加了三行代码就通过了。还要#include <sapi.h>
Arkist 2013-06-01
  • 打赏
  • 举报
回复
加上这个试试:
HRESULT r = OleInitialize(0);
if (r != S_OK && r != S_FALSE)
{qWarning("Qt:初始化Ole失败(error %x)",(unsigned int)r);}
看看这个: http://blog.sina.com.cn/s/blog_8a7012cf01014aot.html

16,787

社区成员

发帖
与我相关
我的任务
社区描述
Qt 是一个跨平台应用程序框架。通过使用 Qt,您可以一次性开发应用程序和用户界面,然后将其部署到多个桌面和嵌入式操作系统,而无需重复编写源代码。
社区管理员
  • Qt
  • 亭台六七座
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧