我需要使用JOLT转换JSON。我是JOLT转型的新手。以下是详细信息。我们正在尝试在NiFi中使用Jolt转换来转换json。
这是输入
{
"Parent": {
"Child": {
"GrandChild": [
{
"DeepDown": [
{
"Field2": "2019-01-29T11:32:45",
"Field1": "015",
"Field3": "data2"
}
]
},
{
"DeepDown": [
{
"Field2": "2019-01-30T11:32:45",
"Field1": "016",
"Field3": "data1"
}
]
}
]
}
}
}
这是我写的JOLT(感谢HariKrishna进行了更新!)
[
{
"operation": "shift",
"spec": {
"Parent": {
"Child": {
"GrandChild": {
"*": {
"DeepDown": {
"*": {
"Field1": "Root.RepeatThis.[].Element1",
"Field2": "Root.RepeatThis.[].Element2",
"Field3": "Root.RepeatThis.[].Element3"
}
}
}
}
}
}
}
}
]
我期望以下输出。
{
"Root" : {
"RepeatThis" : [ {
"Element1" : "015",
"Element2" : "2019-01-29T11:32:45",
"Element3" : "data2"
}, {
"Element1" : "016",
"Element2" : "2019-01-30T11:32:45",
"Element3" : "data1"
} ]
}
}
我无法使循环工作。这是我从编写的JOLT中获得的输出。
{
"Root" : {
"RepeatThis" : [ {
"Element1" : "015"
}, {
"Element2" : "2019-01-29T11:32:45"
}, {
"Element3" : "data2"
}, {
"Element1" : "016"
}, {
"Element2" : "2019-01-30T11:32:45"
}, {
"Element3" : "data1"
} ]
}
}
答案 0 :(得分:0)
尝试使用此JOLT规范
[
{
"operation": "shift",
"spec": {
"Parent": {
"Child": {
"GrandChild": {
"*": {
"DeepDown": {
"*": {
"Field2": "Root.RepeatThis.[].Element2"
}
}
}
}
}
}
}
}
]
答案 1 :(得分:0)
以下代码将产生所需的输出,<ion-item>
将使用GrandChild的数组位置(从当前上下文向上移动3个级别),从而正确地将它们分组:
[&3]