1

我想使用JSONata根据 JSON 对象中的键对数组中的 json 对象进行分组。

例如,我想根据下面给出的 JSON 示例的名称对汽车进行分组。

[
  {
    "car" : "audi",
    "color" : "blue",
    "reg" : 133434
  },
   {
    "car" : "benz",
    "color" : "red",
    "reg" : 134444
  },
   {
    "car" : "audi",
    "color" : "red",
    "reg" : 134884
  }
]

预期产出

{
  "audi" : [
    {
    "car" : "audi",
    "color" : "blue",
    "reg" : 133434
    },
    {
    "car" : "audi",
    "color" : "red",
    "reg" : 134884
    }
  ],
  "benz" : [
    {
    "car" : "benz",
    "color" : "red",
    "reg" : 134444
    }
   ]
}
4

1 回答 1

1
$${car: [$.{"car": car, "color": color, "reg": reg}]}

该文档几乎给出了解决方案:

https://docs.jsonata.org/sorting-grouping

为了确保每个组的值(即使只有一个)存储在一个数组中,[...]需要一个显式的列表构造。

于 2020-12-19T12:49:05.323 回答