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 № 1Avec 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
}
}