首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Qt从QVariantList获取项目

使用Qt从QVariantList获取项目
EN

Stack Overflow用户
提问于 2020-07-31 17:04:53
回答 1查看 131关注 0票数 0

我使用ActiveX从Qt中踢出Excel,并使用特定的范围检索数据数组。数据类型是QVariant,但在调试器中写为"QVariant(QVariantList)“。它大约有1000个项目,我如何访问/获取这些项目?

这是我生成的代码。

代码语言:javascript
复制
QAxObject* excel = new QAxObject( "Excel.Application", 0 );
QAxObject* workbooks = excel->querySubObject( "Workbooks" );
QAxObject* workbook = workbooks->querySubObject( "Open(const QString&)", filename );
QAxObject* sheets = workbook->querySubObject( "Worksheets" );
QAxObject* sheet = sheets->querySubObject( "Item( int )", 1);
QAxObject* range = sheet->querySubObject("Range(A2:A1002)");
QVariant data = range->dynamicCall("value"); // the data I want to retrieve
EN

回答 1

Stack Overflow用户

发布于 2020-07-31 17:08:28

代码语言:javascript
复制
QVariant data = range->dynamicCall("value");
QVariantList list = data.toList();
for (/*const*/ auto &v : list) {
    /// work with QVariant v
}

在Qt文档中:

对于最常见的Qt数据类型,

QVariant类就像一个联合。

“最常见的Qt数据类型”包括QVariantList。因此,如果您确定QVariant的类型为QVariantList,则可以使用QVariant的成员函数将其转换为QVariantList。如果您不能完全确定您的QVariant实际上是一个QVariantList,则应该在调用QVariant.toList()之前使用QVariant.canConvert(targetTypeId)进行验证。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63188861

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档