laz*_*ter 7 json key filter jq
新手jq用户在这里,挣扎于以下几点:
我有以下 json,需要根据关键字过滤键并打印出整个对象(不仅仅是键)或某些键/值对。请注意 JSON 的嵌套对象结构,这是有意的。
{
"timers": {
"timerWithAKeywordAPlusBlah": {
"count": 1,
"max": 0,
"min": 0
},
"timerWithAKeywordB": {
"count": 2,
"max": 0
},
"timerWithAKeywordAPlusBlahBlah": {
"count": 2385,
"max": 2,
"min": 1
}
}
}
Run Code Online (Sandbox Code Playgroud)
期望的输出:
"timerWithAKeywordAPlusBlah": {
"count": 1,
"max": 0,
"min": 0
},
"timerWithAKeywordAPlusBlahBlah": {
"count": 2385,
"max": 2,
"min": 1
}
Run Code Online (Sandbox Code Playgroud)
我尝试过的事情:
我可以打印出键名,但无法弄清楚如何访问整个对象。
cat timers.json| jq '.timers | keys[] | select(contains("KeywordA")) '
Run Code Online (Sandbox Code Playgroud)
在此回复中,我将假设您希望输出是有效的 JSON。如果您希望输出采用其他形式,您可以简单地添加一些额外的过滤器。
无论如何,诀窍是选择对象,而不是键,如下所示:
.timers
| with_entries( select(.key|contains("KeywordA") ) )
Run Code Online (Sandbox Code Playgroud)
使用您的(修改后的)输入,这会产生:
{
"timerWithAKeywordAPlusBlah": {
"count": 1,
"max": 0,
"min": 0
},
"timerWithAKeywordAPlusBlahBlah": {
"count": 2385,
"max": 2,
"min": 1
}
}
Run Code Online (Sandbox Code Playgroud)
然后,您可以提取最终需要的任何细节。
| 归档时间: |
|
| 查看次数: |
3755 次 |
| 最近记录: |