Таким образом, я могу установить значения для объектов в простом 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"}
}
]
}
Я не могу изменить значение. Есть ли какой-нибудь простой способ сделать это? Я пытался найти решение безуспешно!
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
}
Других решений пока нет …