2014-09-18 3 views
1

В моем приложении я использую объект 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 по индексу, а не только по имени?

ответ

3

первый совет: может быть, вы можете использовать этот код вместо, который является более удобным для чтения

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; 
    } 
Смежные вопросы