0

给定这样的数据:

cat << EOF > xyz.json
[
  {
    "batch_id": 526,
    "aCods": [
      "IBDD879"
    ]
  },
  {
    "batch_id": 357,
    "aCods": [
      "IBDD212"
    ]
  }
]
EOF

获得此结果的正确方法是什么?

[
  {
    "batch_id": "00000526",
    "aCods": [
      "IBDD879"
    ]
  },
  {
    "batch_id": "00000357",
    "aCods": [
      "IBDD212"
    ]
  }
]

我尝试了三种不同的命令,希望能够使用该元素上的函数结果来更新数组中的对象元素。

我只是找不到正确的语法。

jq -r '.[] | .batch_id |= 9999999' xyz.json;

{
  "batch_id": 9999999,
  "aCods": [
    "IBDD879"
  ]
}
{
  "batch_id": 9999999,
  "aCods": [
    "IBDD212"
  ]
}
jq -r '.[] | lpad("\(.batch_id)";8;"0")' xyz.json;
00000526
00000357
jq -r '.[] | .batch_id |= lpad("\(.batch_id)";8;"0")' xyz.json;
jq: error (at /dev/shm/xyz.json:14): Cannot index number with string "batch_id"
4

1 回答 1

2

假设您正在尝试使用lpad/2from this peak's comment,您可以这样做

def lpad($len; $fill): tostring | ($len - length) as $l | ($fill * $l)[:$l] + .;
map(.batch_id |= lpad(8; "0"))

这里的关键是当使用更新赋值运算符时|=,被修改的字段是在内部传递的,因此您不必在 RHS 中显式调用它

于 2020-09-15T17:30:49.757 回答