使用excel->querySubObject(“Workbooks“);出现返回值为NULL处理方法

问题:

在QCoreApplication 控制台类下使用QAxObject操作excel时,会出现excel->querySubObject("Workbooks");返回值为空的情况。

#include <QtCore/QCoreApplication>


int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    //错误


    return a.exec();
}

解决方案:

将QCoreApplication类修改为QApplication类即可解决。

#include <QtWidgets/QApplication>


int main(int argc, char *argv[])
{
	QApplication a(argc, argv);

	//正确

	return a.exec();
}

注:此方法需要修改控制台类,对于特定的项目可能无法接受。

其他解决方案:

操作Excel时,workBooks 返回值为NULL。QAxObject指针为NULL的解决办法_Empty8888的博客-CSDN博客_workbook为空

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这段代码的主要作用是遍历指定文件夹下的所有.xls文件,然后打开每个文件,遍历每个工作表,查找其中的指定字符串,并将包含该字符串的单元格位置输出到程序界面。下面是代码的详细解释: 1. QDir dir("C:/Users/Chark Zhou/Desktop/Log"); // 指定文件夹路径 这行代码指定了要遍历的文件夹路径,其中"C:/Users/Chark Zhou/Desktop/Log"为文件夹的绝对路径。 2. foreach (QString file, dir.entryList(QStringList() << "*.xls", QDir::Files)) { 这行代码使用foreach循环遍历文件夹中的所有.xls文件,其中QStringList() << "*.xls"指定只遍历后缀为.xls的文件,QDir::Files表示只遍历文件,不包括子文件夹。 3. QAxObject *excel = new QAxObject("Excel.Application"); 这行代码创建了一个Excel应用程序的COM对象。后面的代码将使用该对象来打开Excel文件并读取其中的数据。 4. QAxObject *workbooks = excel->querySubObject("Workbooks"); 这行代码获取了Excel应用程序中的所有工作簿。 5. QAxObject *workbook = workbooks->querySubObject("Open(const QString&)", dir.absoluteFilePath(file)); 这行代码打开了Excel文件,并将其作为一个工作簿对象返回。其中dir.absoluteFilePath(file)是当前遍历到的文件的绝对路径。 6. QAxObject *sheets = workbook->querySubObject("Worksheets"); 这行代码获取了工作簿中的所有工作表。 7. int sheetCount = sheets->dynamicCall("Count()").toInt(); 这行代码计算出工作簿中的工作表数量。 8. for (int i = 1; i <= sheetCount; i++) { 这行代码使用for循环遍历所有的工作表。 9. QAxObject *sheet = sheets->querySubObject("Item(int)", i); 这行代码获取指定序号的工作表。 10. QAxObject *usedRange = sheet->querySubObject("UsedRange"); 这行代码获取工作表中的使用范围。 11. QAxObject *rows = usedRange->querySubObject("Rows"); 这行代码获取使用范围中的所有行。 12. QAxObject *columns = usedRange->querySubObject("Columns"); 这行代码获取使用范围中的所有列。 13. for (int row = 1; row <= rowCount; row++) { for (int column = 1; column <= columnCount; column++) { 这两行代码使用双重for循环遍历每个单元格。 14. QAxObject *cell = sheet->querySubObject("Cells(int,int)", row, column); 这行代码获取指定行列的单元格。 15. QString value = cell->dynamicCall("Value()").toString(); 这行代码获取单元格中的,并将其转换为QString类型。 16. if (value.contains(" ANDY")) { 这行代码判断单元格中是否包含指定字符串" ANDY"。 17. ui->textBrowser->append(QString::fromLocal8Bit("文件 %1, 表格 %2, 位置 %3").arg(file).arg(i).arg(cell->dynamicCall("Address()").toString())); 这行代码将包含指定字符串的单元格的文件名、工作表名称、单元格位置输出到程序界面。 18. cell->clear(); delete cell; 这两行代码清空单元格中的内容,并释放单元格对象。 19. delete sheet; 这行代码释放当前工作表对象。 20. workbook->dynamicCall("Close()"); delete workbook; delete workbooks; 这几行代码关闭工作簿对象,并释放工作簿、工作簿集对象。 21. excel->dynamicCall("Quit()"); delete excel; 这几行代码关闭Excel应用程序对象,并释放Excel应用程序对象。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值