Я пытаюсь преобразовать следующий код JSON
{
"data": {
"keyvalues": [
{
"key": "location",
"value": "sydney, au"
},
{
"key": "weather",
"value": "sunny"
}
]
},
"food": {
"name": "AllFoods",
"date": "2018-03-08T09:35:17-03:00",
"count": 2,
"food": [
{
"name": "chocolate",
"date": "2018-03-08T12:59:58-03:00",
"rating": "10",
"data": null
},
{
"name": "hot dog",
"date": "2018-03-08T09:35:17-03:00",
"rating": "7",
"data": {
"keyvalues": [
{
"key": "topping",
"value": "mustard"
},
{
"key": "BUN type",
"value": "toasted"
},
{
"key": "servings",
"value": "2"
}
]
}
}
]
}
}
в нечто более простое, используя JOLT (в NIFI).Ввод первых атрибутов food
верхнего уровня (name
, date
, count
) в header
, затем вытягивание вложенного массива food
вверх, а затем сглаживание food.data.keyvalues
в диктовку/ HashMap.
{
"header": {
"location": "sydney, au",
"weather": "sunny",
"date": "2018-03-08",
"count": 2
},
"foods": [
{
"name": "chocolate",
"date": "2018-03-08T12:59:58-03:00",
"rating": "10"
},
{
"name": "hot dog",
"date": "2018-03-08T09:35:17-03:00",
"rating": "7",
"topping": "mustard",
"bun_type": "toasted",
"servings": "2"
}
]
}
У меня работает первая data
часть, но я не уверен, как обращаться с вложенным элементом food
.Информация food
верхнего уровня должна быть перемещена в секцию header
, а массив food
второго уровня должен сгладить data.keyvalues
.
Current spec ... (обрабатывает толькоtop data.keyvalues
)
[
{
"operation": "shift",
"spec": {
"data": {
"keyvalues": {
"*": { "@value": "@key" }
}
}
}
}
]