qt使用QAxObject操作excel程序关闭之后excel进程未被关闭的解决方案

💂 个人主页:pp不会算法^ v ^
🤟 版权: 本文由【pp不会算法v】原创、在CSDN首发、需要转载请联系博主
💬 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦

今天突然发现电脑变得很卡,我以为内存占用率过高了一看才50%,又以为c盘满了一看还有50多G,后面打开任务管理器我被吓了一条,几十个excel进程,

后面想了一下应该是我那个导出excel的qt程序引起的,然后我运行程序发现开启了四个excel进程,程序关闭之后这四个进程却没有结束,由于通过QAxObject去操作excel的时候使用的是本机的excel软件所以会开启excel进程,但是我明明在析构函数中执行了这句:

    if (excelApp) {
        //关闭工作簿
        if(workBook!=nullptr)
        workBook->dynamicCall("Close(Boolean)",true);
        //关闭excel
        excelApp->dynamicCall("Quit()");
        delete excelApp;
        excelApp = nullptr;
    }

后面经过多次尝试和查阅资料我总结出了两种解决办法:
1、连接excel控件的时候选择显示窗体

    excelApp = new QAxObject();
    // 连接Excel控件
    excelApp->setControl("Excel.Application");
    // 显示窗体
    excelApp->dynamicCall("SetVisible(bool)","true");
    // 不显示任何警告信息。如果为true那么在关闭时会出现类似“文件已修改,是否保存”的提示

这样程序结束之后进程可以正常结束

2、workbook->dynamicCall(“Save()”); 和 workbook->dynamicCall(“Close()”); 改为: workbook->dynamicCall(“Save()”, true); workbook->dynamicCall(“Close(Boolean)”, true);

原因就是如果显示指定flag参数为true会执行强制操作

    if (workBook)
        {
            QAxObject *worksheets =workBook->querySubObject("Sheets");//获取工作表集合
            QAxObject *first_sheet = worksheets->querySubObject("Item(int)", 1);
            first_sheet->dynamicCall("Select()");//选中 sheet
            int sheet_count = worksheets->property("Count").toInt();  //获取工作表数目
            first_sheet = worksheets->querySubObject("Item(int)", sheet_count);
            first_sheet->dynamicCall("delete");//删除最后一个sheet页,为:sheet1
        }
    //保存至filepath,注意一定要用QDir::toNativeSeparators将路径中的"/"转换为"\",不然一定保存不了。
    workBook->dynamicCall("SaveAs(const QString&)",QDir::toNativeSeparators(fileName),true);
    // 关闭 Excel 文件
    workBook->dynamicCall("Close(Boolean)",true);
  • 10
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

pp不会算法^v^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值