繁体   English   中英

通过索引从 QJsonObject 获取值

[英]Get value from QJsonObject by index

在我的应用程序中,我使用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获取适当的字段?

第一个建议:也许你可以改用这段代码,它更具可读性

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;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM