我有这个 JSON 文件:
{ “key11”:1010, “key12”:12120, “key13”:12103 }
如何jq
检查 a 对应的值是否key[0-9][0-9]
为零,jq
如果有则成功退出,否则退出?
我从上一个问题中得到了这个脚本
#!/bin/bash
json=$(cat <<EOF
{"key11":12120,"key11_":13,"key11_yes":12107,
"key12":13492,"key12_no":9,"key12_yes":13483,
"key13":10200,"key13_no":9,"key13_yes":10191,
"key21":16756,"key21_no":30,"key21_yes":16726,
"key22":17057,"key22_no":34,"key22_yes":17023,
"key23":16798,"key23_no":25,"key23_yes":16773,
"key31":2733,"key31_yes":2733,
"key32":2561,"key32_yes":2561,
"key33":2570,"key33_yes":2570}
EOF
)
json2=$(echo ${json}|jq 'with_entries(if (.key|test("key[0-9][0-9]$")) then ( {key: .key, value: .value } ) else empty end )')
结果是:
{ "key11": 12120, "key12": 13492, "key13": 10200, "key21": 16756, "key22": 17057, "key23": 16798, "key31": 2733, "key32": 2561, "key33": 2570 }
现在我想检查附加到所有键的值$json2
,然后如果任何的条目为零回报0
。
答案1
any
是一个内置过滤器,如果任何一项为 true,则返回 true,否则为假。--exit-status
/-e
导致jq
退出0
iff 最后的输出既不是 false 也不是 null。
如果您已经将文档筛选为仅包含您关心的键(如脚本中所示),则可以执行以下操作:
previous_command | jq -e 'any( .[] ; . == 0 )'
.[]
取出所有值,并且any
只有在其中找到零时才会输出 true。或者,[.[]|.==0]|any
或者map(.==0) | any
;选择您认为最清晰的一个。
您也可以一次性完成整个事情,从而节省浪费的jq
过程:
jq -e '[to_entries | .[] | select(.key | test("key[0-9][0-9]$")) | .value == 0 ] | any' data.json
这将选择所有匹配的键并检查每个值是否为 0,然后通过管道传输结果集合any
,如果有任何零,则退出 0。如果你确定不存在 NaN,你也可以将它们全部相乘reduce
。