在我的应用程序中,我使用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
获取适当的字段而不是仅通过名称?
答案 0 :(得分:2)
第一个建议: 也许你可以使用这个代码,它更具可读性
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;
}