Как изменить QJsonObject

Таким образом, я могу установить значения для объектов в простом json-файле.

Qt код:

if(file.open(QIODevice::ReadOnly)){
QJsonDocument doc = QJsonDocument::fromJson(file.readAll());
QJsonObject obj = doc.object();
obj["gender"] = "female";
doc.setObject(obj);
manager.put(request, doc.toJson());
}

Простой файл JSON:

{
"resourceType": "Patient",
"gender": "male",
"birthDate": "2018-08-21"}

Так что этот код меняет значение пола на женский.

Но когда я использую больший JSON, где есть «объекты под объектами»

{
"resource": {
"resourceType": "Patient",
"id": "530f8eb0-1f0b-41b0-b94",
"text": {
"status": "generated",
"div": "<div xmlns=\"http://www.w3.org/1999/xhtml\">Teppo Testman\n            <a name=\"mm\"></a>\n          </div>"},
"name": [{
"family": "Testman",
"given": [
"Teppo"]
}],
"gender": "male",
"birthDate": "1993-02-12"}
}

Обновить:

{
"resourceType": "Bundle",
"id": "17772d63-3b14-494f-8182-06b67c970550",
"meta": {
"versionId": "1",
"lastUpdated": "2018-08-15T12:08:48.036+00:00"},
"type": "collection",
"entry": [{
"resource": {
"resourceType": "Observation",
"text": {
"status": "generated",
"div": "<div xmlns=\"http://www.w3.org/1999/xhtml\">Height\n            <a name=\"mm\"></a>\n          </div>"},
"status": "final",
"code": {
"coding": [{
"system": "http://loinc.org",
"code": "8302-2",
"display": "Body height"}]
},
"subject": {
"reference": "Patient/530f8eb0-1f0b-41b0-b94b-c25a14656645"},
"valueQuantity": {
"value": 166,
"unit": "cm"}
}
},
{
"resource": {
"resourceType": "Observation",
"text": {
"status": "generated",
"div": "<div xmlns=\"http://www.w3.org/1999/xhtml\">BMI\n            <a name=\"mm\"></a>\n          </div>"},
"status": "final",
"code": {
"coding": [{
"system": "http://loinc.org",
"code": "39156-5",
"display": "Body mass index (BMI) [Ratio]"}]
},
"subject": {
"reference": "Patient/530f8eb0-1f0b-41b0-b94b-c25a14656645"},
"valueString": "23"}
},
{
"resource": {
"resourceType": "Observation",
"text": {
"status": "generated",
"div": "<div xmlns=\"http://www.w3.org/1999/xhtml\">FEV1 [l]\n            <a name=\"mm\"></a>\n          </div>"},
"status": "final",
"code": {
"coding": [{
"system": "http://loinc.org",
"code": "18759-1",
"display": "Spirometry study"}]
},
"subject": {
"reference": "Patient/530f8eb0-1f0b-41b0-b94b-c25a14656645"},
"valueQuantity": {
"value": 2,
"unit": "l"}
}
},
{
"resource": {
"resourceType": "Observation",
"text": {
"status": "generated",
"div": "<div xmlns=\"http://www.w3.org/1999/xhtml\">FEV6 [l]\n            <a name=\"mm\"></a>\n          </div>"},
"status": "final",
"code": {
"coding": [{
"system": "http://loinc.org",
"code": "18759-1",
"display": "Spirometry study"}]
},
"subject": {
"reference": "Patient/530f8eb0-1f0b-41b0-b94b-c25a14656645"},
"valueQuantity": {
"value": 2.9,
"unit": "l"}
}
},
{
"resource": {
"resourceType": "Observation",
"text": {
"status": "generated",
"div": "<div xmlns=\"http://www.w3.org/1999/xhtml\">PEF [l/s]\n            <a name=\"mm\"></a>\n          </div>"},
"status": "final",
"code": {
"coding": [{
"system": "http://loinc.org",
"code": "18759-1",
"display": "Spirometry study"}]
},
"subject": {
"reference": "Patient/530f8eb0-1f0b-41b0-b94b-c25a14656645"},
"valueQuantity": {
"value": 6.5,
"unit": "l/s"}
}
},
{
"resource": {
"resourceType": "Patient",
"id": "530f8eb0-1f0b-41b0-b94b-c25a14656645",
"text": {
"status": "generated",
"div": "<div xmlns=\"http://www.w3.org/1999/xhtml\">Teppo Testman\n            <a name=\"mm\"></a>\n          </div>"},
"name": [{
"family": "Testman",
"given": [
"Teppo"]
}],
"gender": "male",
"birthDate": "1993-02-12"}
}
]
}

Я не могу изменить значение. Есть ли какой-нибудь простой способ сделать это? Я пытался найти решение безуспешно!

0

Решение

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

if(file.open(QIODevice::ReadOnly)){
QJsonDocument doc = QJsonDocument::fromJson(file.readAll());
QJsonObject root = doc.object();
QJsonObject res = root["resource"].toObject();
res["gender"] = "female";
root["resource"] = res;
doc.setObject(root);
//another code
manager.put(request, doc.toJson());
}

Обновить:

Идея та же, вы не можете получить доступ напрямую, но вы должны знать структуру JSON. Хотя у меня есть наблюдение, например, над дочерними элементами элементов, являющимися массивом, нормальным является то, что эти дочерние элементы имеют одинаковую структуру, но в вашем случае последний отличается, что необычно.

if(file.open(QIODevice::ReadOnly)){
QJsonDocument doc = QJsonDocument::fromJson(file.readAll());
QJsonObject root = doc.object();
QJsonArray entries = root["entry"].toArray();
for(int i=0; i < entries.count(); i++){
QJsonObject obj = entries[i].toObject();
QJsonObject objs = obj["resource"].toObject();
if(objs.contains("gender")){
objs["gender"]= "female";
obj["resource"] = objs;
entries[i] = obj;
}
}
root["entry"] = entries;
doc.setObject(root);
// another process
}
0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]