/ / Comment nettoyer un json d'objets vides imbriqués et de tableaux vides - json, scala, playframework, playframework-2.0

Comment nettoyer un json des objets imbriqués vides et des tableaux vides - json, scala, playframework, playframework-2.0

J'ai un objet imbriqué tel que:

{
"name:"ABC",
"nest1":{
{
"field1": null,
"field2": null,
"field3": [],
"field4": {},
},
"nest2":{
"field1":"123",
"field2":null
}
}

Je veux nettoyer ce JSON et m'assurer que le résultat sera:

{
"name:"ABC",
"nest2":{
"field1":"123"
}
}

J'ai écrit le code suivant:

def withoutNullAndEmptyObj(json: JsValue): JsValue = {
json match {
case JsObject(fields) =>
if (fields.isEmpty) JsNull
else{
fields.foldLeft(new JsObject(Map()))((agg, field) =>
field match{
case (_, JsNull) => agg
case other@(name, value: JsArray) => if (value == emptyArray) agg else agg+other
case (name, value: JsObject) => if (value == emptyObject) agg else agg+(name, withoutNullAndEmptyObj(value))
case other@(name, value) => agg+other
}
)
}
case other => other
}
}

Le problème est que cela ne fonctionne pas complètement. Il produira le json suivant:

{
"name:"ABC",
"nest1":{},
"nest2":{
"field1":"123"
}
}

ce qui ne suffit pas.

Réponses:

4 pour la réponse № 1

Avec une légère modification de votre code actuel:

def withoutNullAndEmptyObj(json: JsValue): JsValue = {
json match {
case JsObject(fields) =>
if (fields.isEmpty) JsNull
else {
fields.foldLeft(new JsObject(Map()))((agg, field) =>
field match {
case (_, JsNull)                    => agg
case other @ (name, value: JsArray) => if (value == emptyArray) agg else agg + other
case (name, value: JsObject) => {
if (value == emptyObject) agg
else {
//added further check on else part.
val nested = withoutNullAndEmptyObj(value);
if (nested == emptyObject)
agg
else
agg + (name, nested)
}
}
case other @ (name, value) => agg + other
})
}
case other => other
}
}