gpt4 book ai didi

c++ - 如果 Excel.Application 不可见,activeQt 无法打开 *.xls

转载 作者:行者123 更新时间:2023-11-28 05:00:04 27 4
gpt4 key购买 nike

当尝试使用 activeQt 和代码打开 *.xls 文件时:

QAxObject *excel = new QAxObject("Excel.Application", this);
QAxObject *workbooks = excel->querySubObject("Workbooks");
QAxObject *workbook = workbooks->querySubObject("Open(const QString&)", "c:\\somefile.xls");
QAxObject *worksheets = workbook->querySubObject("Worksheets");
QAxObject *worksheet = worksheets->querySubObject("Item(int)", 1);

我得到一个错误:

QAxBase: Error calling IDispatch member Open: Unknown error

The program has unexpectedly finished.

我在网上搜索了一下,发现如果 excel 的属性 Visible 设置为 true,一切都会顺利进行错误。有趣的是,我必须在打开文件之前设置这个属性,否则程序会崩溃。但是,如果我在打开文件后将其设置为 true,excel 应用程序将正确显示(向我显示文件中的数据),但程序会崩溃。

我正在寻找真正的解决方案,或者问题的原因。我不希望用户在任何时候都可以看到 excel

所以让它可见然后不可见对我来说不是一个令人满意的解决方案

附注同样的代码曾经在我的笔记本电脑上 100% 正确地工作了整整一个月,然后它开始崩溃了。在我的工作场所,他们在电脑上遇到了同样的问题,所以我的同事曾经在我的电脑上运行他的应用程序来检查它们是否工作。这是一个坏习惯,因为我们不知道用户会遇到什么情况

我正在使用 Qt 5.8.0、MS office 2016 和 MS office 2012。

最佳答案

很久以前就找到了解决方案,抱歉没有更新。

整个问题是因为 Foxit Pro 插件。我在 MS Office 中停用了它,一切正常。

附言问题可能出在任何 MS Office 应用程序中,确保在使用 COM api 之前将其关闭。

关于c++ - 如果 Excel.Application 不可见,activeQt 无法打开 *.xls,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46256787/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com