jq:如何更改JSON的结构以避免笛卡尔积?

我有很薄的 JSON 输入:

[
  {
    "x": [
      "2020-02-24T00:00:00",
      "2020-02-25T00:00:00",
      "2020-02-26T00:00:00"
    ],
    "y": [
      3,
      2,
      6
    ]
  }
]

我想获得:

[
  {
    "a": "2020-02-24T00:00:00",
    "b": 3
  },
  {
    "a": "2020-02-25T00:00:00",
    "b": 2
  },
  {
    "a": "2020-02-26T00:00:00",
    "b": 6
  }
]

如果我申请,.[]|{a:.x[],b:.y[]}我将获得笛卡尔积(9 项)。

如何更改此 JSON 的结构以避免笛卡尔积?

回答

引入一个“$-variable”可以让事情简单明了:

map(range(0; .x|length) as $i
    | {a: .x[$i], b: .y[$i]})

但是 $-variable 免费解决方案只需要多一行:

map([.x, .y]
    | transpose[]
    | {a: .[0], b: .[1]})


以上是jq:如何更改JSON的结构以避免笛卡尔积?的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>