通过索引从 QJsonObject 中获取值

Posted

技术标签:

【中文标题】通过索引从 QJsonObject 中获取值【英文标题】:Get value from QJsonObject by index 【发布时间】:2014-09-18 03:32:04 【问题描述】:

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


    status:"ok",
    data: [
         field1:"value1", field2:"value2", field3:"value3" ,
         field1:"value4", field2:"value5", field3:"value6" ,
         field1:"value7", field2:"value8", field3:"value9" 
    ]

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

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(); 

但有时我需要通过索引而不是名称来获取值。好的,我执行以下操作:

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 按索引而不是仅按名称获取适当的字段?

【问题讨论】:

【参考方案1】:

第一个建议: 或许你可以改用这段代码,这样更易​​读

responseObject["status"].toString() == "ok"

这是你的问题建议

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

QJsonArray dataObject = responseObject["data"].toArray();
QJsonArray::iterator it;
for (it = dataObject.begin(); it != dataObject.end(); it++) 
    QString key = it->first;
    QString value = it->second;

【讨论】:

以上是关于通过索引从 QJsonObject 中获取值的主要内容,如果未能解决你的问题,请参考以下文章

如何向 qjsonobject 中的键添加多个值

如何修改 QJsonObject

如何从 Pandas DataFrame 中获取值而不是索引和对象类型

如果列表包含布尔值,如何从列表中获取整数的索引?

有没有办法使用 QJsonObject 在整个 json 文件中找到一个键?

如何从jstl中的foreach循环中获取索引值