使用 jq 在 json 中进行类似正则表达式的搜索
regex-like search in a json with jq
我有这个json,我想获取适合可变子网的相应子网的 ID。
subnet="192.168.112"
json='{
"subnets": [
{
"cidr": "192.168.112.0/24",
"id": "123"
},
{
"cidr": "10.120.47.0/24",
"id": "456"
}
]
}'
因为 jq 不支持正则表达式。我发现获得正确 id 的唯一方法是像这样混合 grep、sed 和 jq :
tabNum=$((`echo ${json} | jq ".subnets[].cidr" | grep -n "$subnet" | sed "s/^\([0-9]\+\):.*$//"` - 1))
NET_ID=`echo ${json} | jq -r ".subnets[${tabNum}].id"`
有没有办法只使用 jq 获取 id?
我不太清楚您提供的脚本的作用,但它似乎只查找包含提供的子集的字符串。我建议使用 contains
or startswith
。示例脚本如下所示:
echo "${json}" | jq --arg subnet "$subnet" '.subnets[] | select(.cidr | startswith($subnet)).id'
既然你提到了正则表达式:jq 的最新版本 1.5 包括正则表达式支持(感谢 Jeff Mercado 指出了这一点!)而且,如果你必须经常处理字符串操作问题,我建议你检查一下出来了。
我有这个json,我想获取适合可变子网的相应子网的 ID。
subnet="192.168.112"
json='{
"subnets": [
{
"cidr": "192.168.112.0/24",
"id": "123"
},
{
"cidr": "10.120.47.0/24",
"id": "456"
}
]
}'
因为 jq 不支持正则表达式。我发现获得正确 id 的唯一方法是像这样混合 grep、sed 和 jq :
tabNum=$((`echo ${json} | jq ".subnets[].cidr" | grep -n "$subnet" | sed "s/^\([0-9]\+\):.*$//"` - 1))
NET_ID=`echo ${json} | jq -r ".subnets[${tabNum}].id"`
有没有办法只使用 jq 获取 id?
我不太清楚您提供的脚本的作用,但它似乎只查找包含提供的子集的字符串。我建议使用 contains
or startswith
。示例脚本如下所示:
echo "${json}" | jq --arg subnet "$subnet" '.subnets[] | select(.cidr | startswith($subnet)).id'
既然你提到了正则表达式:jq 的最新版本 1.5 包括正则表达式支持(感谢 Jeff Mercado 指出了这一点!)而且,如果你必须经常处理字符串操作问题,我建议你检查一下出来了。