Qt在线程中操作excel问题解决

问题描述

在qt界面主线程中使用QAxObject类对excel进行操作时,功能均正常,当将代码移植到子线程中使用时,出现错误。错误提示如下:

QAxBase::setControl: requested control Excel.Application could not be instantiated
QAxBase::dynamicCallHelper: Object is not initialized, or initialization failed

分析

查阅资料后发现,在调用COM库中的函数之前,需要先将COM库初始化。初始化COM库我们需要使用windows提供的API函数CoInitializeEx,函数原型如下:

HRESULT CoInitializeEx(
void * pvReserved,
DWORD dwCoInit
);

解决

在项目中引入#include “Windows.h”
在调用COM库函数之前,增加代码:

CoInitializeEx(NULL, COINIT_MULTITHREADED);

COINIT_MULTITHREADED为const 枚举,表示组件进入进程唯一的MTA套间。
返回值:
S_OK :COM库初始化成功。
S_FALSE :当前线程上,COM库已经被初始化。
RPC_E_CHANGED_MODE :COM库已经被初始化且传入参数设置的并发模式和本次不同

  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值