В моем приложении я использую объект json
, чтобы получить результат из удаленной базы данных. Обычно строка ответа выглядит следующим образом:Получить значение от QJsonObject по индексу
{
status:"ok",
data: [
{ field1:"value1", field2:"value2", field3:"value3" },
{ field1:"value4", field2:"value5", field3:"value6" },
{ field1:"value7", field2:"value8", field3:"value9" }
]
}
Он выглядит хорошо, и я могу получить значение из speciified строк/цв по:
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
по индексу, а не только по имени?