0

尝试使用 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:调用 IDispatch 成员打开时出错:未知错误

程序意外结束。

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

我正在寻找一个真正的解决方案,或问题的原因。我不希望excel用户随时看到。

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

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

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

4

1 回答 1

1

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

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

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

于 2018-03-10T17:14:02.107 回答