使用 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 指出了这一点!)而且,如果你必须经常处理字符串操作问题,我建议你检查一下出来了。