这有点棘手,但可以使用reduce
. 整个事情可能看起来像这样:
selected_subnets_json=$(echo "\"$selected_subnets\"" | jq -c -M 'split(" ")')
echo "$input" | jq -M '.elements = [.elements[] | select(.VPCZoneIdentifier as $id | '"$selected_subnets_json"' | reduce .[] as $v (false; . or $id == $v))]'
第一部分从 shell 列表中创建一个 JSON 数组:
$ echo "\"$selected_subnets\"" | jq -c -M 'split(" ")'
["valueA","valueB"]
第二部分使用reduce
过滤器将.VPCZoneIdentifier
属性与该数组的所有元素进行比较。将selected_subnets_json
变量扩展到其中后,过滤器如下所示:
.elements = [
.elements[] |
select(.VPCZoneIdentifier as $id |
[ "valueA", "valueB" ] | reduce .[] as $v (false; . or $id == $v))
]
也就是说,该elements
属性被它的那些匹配选择标准的元素覆盖
.VPCZoneIdentifier as $id | [ "valueA", "valueB" ] | reduce .[] as $v (false; . or $id == $v))
其中第一部分记住VPCZoneIdentifier
as $id
(因为.
很快将意味着完全不同的东西),并且
[ "valueA", "valueB" ] | reduce .[] as $v (false; . or $id == $v))
是子网数组的或约。它扩展到false or $id == "valueA" or $id == "valueB"
在这种情况下。
如果您希望一口气完成所有操作,则可以编写
echo "$input" | jq -M '.elements = [.elements[] | select(.VPCZoneIdentifier as $id | ("'"$selected_subnets"'" | split(" ")) | reduce .[] as $v (false; . or $id == $v))]'
这基本上以相同的方式工作,除了拆分$selected_subnets
是内联完成的。