首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过索引从QJsonObject获取值

通过索引从QJsonObject获取值
EN

Stack Overflow用户
提问于 2014-09-18 11:32:04
回答 1查看 13.4K关注 0票数 1

在我的应用程序中,我使用json对象从远程数据库获取结果。通常响应字符串如下所示:

代码语言:javascript
复制
{
    status:"ok",
    data: [
        { field1:"value1", field2:"value2", field3:"value3" },
        { field1:"value4", field2:"value5", field3:"value6" },
        { field1:"value7", field2:"value8", field3:"value9" }
    ]
}

它看起来不错,我可以通过以下方式从指定的行/列中获取值:

代码语言:javascript
复制
QJsonDocument jsonResponse = QJsonDocument::fromJson(strReply.toUtf8());
QJsonObject responseObject = jsonResponse.object();
if(responseObject.value("status").toString() == "ok") {
     QJsonArray dataObject = responseObject.value("data").toArray();
     // and here I can get the value, for example 2-nd row, field2
     QString value = dataObject.at(1).toObject().value("field2").toString(); 
}

但有时我需要按索引而不是按名称来获取值。好的,我这样做:

代码语言:javascript
复制
QJsonObject obj = dataObject.at(1).toObject();
QString key = obj.keys().at(1); // I use index here instead of name
QString value = obj.value(key).toString();

但不幸的是,看起来keys()没有保留字段顺序,所以索引为0的键将是其QJsonObject中的第一个字段。

因此,我的问题是:如何才能按索引而不是仅按名称从QJsonObject中获取适当的字段?

EN

回答 1

Stack Overflow用户

发布于 2014-12-08 10:38:34

第一个建议:也许你可以使用下面的代码,它更具可读性

代码语言:javascript
复制
responseObject["status"].toString() == "ok"

这是你的问题建议

也许你可以试试迭代器,下面的代码就是这个例子:

代码语言:javascript
复制
QJsonArray dataObject = responseObject["data"].toArray();
QJsonArray::iterator it;
for (it = dataObject.begin(); it != dataObject.end(); it++) {
    QString key = it->first;
    QString value = it->second;
}
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25903734

复制
相关文章

相似问题

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