使用jq更新dicts数组中的一个值

时间:2015-04-21 12:48:11

标签: json jq

我想更新dict中的值,我只能通过dict中的另一个值来识别。也就是说,鉴于此输入:

[
  {
    "format": "geojson",
    "id": "foo"
  },
  {
    "format": "geojson",
    "id": "bar"
  },
  {
    "format": "zip",
    "id": "baz"
  }
]

我想将baz随附的格式更改为' csv':

[
  {
    "format": "geojson",
    "id": "foo"
  },
  {
    "format": "geojson",
    "id": "bar"
  },
  {
    "format": "csv",
    "id": "baz"
  }
]

我发现这有效:

jq 'map(if .id=="baz" then .format="csv" else . end)' my.json

但这看起来相当冗长,所以我想知道是否有一种更优雅的方式来表达这一点。 jq似乎缺少某种表达式选择器,相当于xpath中的[@id='baz']

(当我开始提问时,我有[.[] |...],然后我发现了map,所以它并不像我想的那么糟糕。)

1 个答案:

答案 0 :(得分:19)

复杂的作业是您正在寻找的:

jq '(.[] | select(.id == "baz") | .format) |= "csv"' my.json

也许不会更短,但要求更优雅。请参阅文档的最后一部分:http://stedolan.github.io/jq/manual/#Assignment

修改:使用map

jq 'map((select(.id == "baz") | .format) |= "csv")' my.json