QT5.9 在线程中导出EXCLE报 CoCreateInstance failure (尚未调用 CoInitialize) 解决办法

错误截图:


原因:因为COM是在GUI线程里初始化和销毁的。在新开的线程里并没有初始化,所以得自己初始化

解决办法:

1.引用头文件 

#include "qt_windows.h"



添加代码之后就可以在线程里运行了.

  • 6
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要实现Qt TableWidget的导出Excel功能,可以使用Qt自带的QAxObject类来操作Excel。 以下是一个示例代码,用于将TableWidget的数据导出到Excel文件: ``` void exportToExcel(QTableWidget *tableWidget, const QString &filePath) { QAxObject *excel = new QAxObject("Excel.Application"); // 创建Excel应用程序 excel->setProperty("Visible", false); // 不显示Excel窗口 QAxObject *workbooks = excel->querySubObject("Workbooks"); QAxObject *workbook = workbooks->querySubObject("Add"); // 创建新的工作簿 QAxObject *worksheets = workbook->querySubObject("Worksheets"); QAxObject *worksheet = worksheets->querySubObject("Item(int)", 1); // 获取第一个工作表 int rowCount = tableWidget->rowCount(); int columnCount = tableWidget->columnCount(); // 将TableWidget的数据写入Excel文件 for (int i = 0; i < rowCount; ++i) { for (int j = 0; j < columnCount; ++j) { QTableWidgetItem *item = tableWidget->item(i, j); if (item) { QString text = item->text(); QAxObject *cell = worksheet->querySubObject("Cells(int,int)", i+1, j+1); cell->setProperty("Value", text); // 设置单元格的值 } } } // 保存Excel文件并退出Excel应用程序 workbook->dynamicCall("SaveAs(const QString&)", QDir::toNativeSeparators(filePath)); workbook->dynamicCall("Close()"); excel->dynamicCall("Quit()"); delete excel; } ``` 该函数的参数为QTableWidget指针和Excel文件路径,用于将TableWidget的数据导出到指定的Excel文件。在函数内部,首先使用QAxObject类创建Excel应用程序,并创建新的工作簿和工作表。然后,将TableWidget的数据写入Excel文件,并保存Excel文件并退出Excel应用程序。 需要注意的是,导出Excel功能涉及到与外部程序(Excel)的交互,因此需要在项目添加ActiveX模块,并在.pro文件添加如下代码: ``` win32: LIBS += -L$$PWD/ -lole32 INCLUDEPATH += $$PWD/ DEPENDPATH += $$PWD/ ``` 希望这个示例代码能够帮到您!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值