在这种情况下,我有一个原始的json看起来如下:
{ "taskDefinition": { "containerDefinitions": [ { "name": "web","image": "my-image","environment": [ { "name": "DB_HOST","value": "localhost" },{ "name": "DB_USERNAME","value": "user" } ] } ] } }
我想原样修改匹配键的值,如下所示:
jq’.taskDefinition.containerDefinitions [0] .environment [] |选择(.name ==“DB_USERNAME”)| .value =“new”’json
我得到了输出
{ "name": "DB_USERNAME","value": "new" }
但我希望更多像就地修改或原始的整个json修改新值,如下所示:
{ "taskDefinition": { "containerDefinitions": [ { "name": "web","environment": [ { "name": "DB_HOST","value": "localhost" },{ "name": "DB_USERNAME","value": "new" } ] } ] } }
是否可以使用jq或任何已知的解决方法?
谢谢.
更新
对于任何想要编辑多值的人,
这是我使用的方法
JQ="" for e in DB_HOST=rds DB_USERNAME=xxx; do k=${e%=*} v=${e##*=} JQ+="(.taskDefinition.containerDefinitions[0].environment[] | select(.name==\"$k\") | .value) |= \"$v\" | " done jq '${JQ%??}' json
我认为应该有更简洁的方式,但这似乎工作正常.
解决方法
如果使用| =,则分配给路径就足够了,例如
jq ' (.taskDefinition.containerDefinitions[0].environment[] | select(.name=="DB_USERNAME") | .value) |= "new" ' infile.json
输出:
{ "taskDefinition": { "containerDefinitions": [ { "name": "web","value": "new" } ] } ] } }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。