我收到了这个混乱的 JSON 数据,我需要提取类型列表:
{
"token/": {
"accessor": "auth_token_909d6a81",
"config": {
"default_lease_ttl": 0,
"max_lease_ttl": 0
},
"description": "token based credentials",
"local": false,
"seal_wrap": false,
"type": "token" <-- I need to extract this value ...
},
"userpass/": {
"similar_to": {
"above": null
},
"description": "",
"local": false,
"seal_wrap": false,
"type": "userpass" <-- ... and this one
},
"request_id": "f2a4c135-f699-f29d-ca7c-3320dce0a550",
"more_keys": "more_values",
"data": {
"more_data": {
"even_more_data": "snipped"
}
},
"you_get_the": "idea"
}
抱歉,复制和粘贴时内联注释弄乱了数据,但这似乎是澄清我的目标的最佳方式:
对于所有以/
,我需要的值.type
,所以上面例子的最终结果是token userpass
.
我设法为根键创建一个工作过滤器:
host:~ user$ jq -r '. | keys[] | endswith("/")' <<< "${json_data}"
false
false
false
true
true
false
我可以使用该过滤器仅获取所需的键,但这只是键本身,而不是它们下面的整个数据结构:
host:~ user$ jq -r '. | keys[] | select(. | endswith("/"))' <<< "${json_data}"
token/
userpass/
我似乎无法将这一切放在一起......
谁能帮我 ?