如何使用JQ从JSON中删除不必要的项



我需要:(示例(

{
"jobs": [
{},
{}
],
"services": {
"service-1": {
"version": "master"
},
"service-2": {
"foo": true,
"version": "master"
},
"service-3": {
"bar": "baz"
}
}
}

制作:

{
"services": {
"service-1": {
"version": "master"
},
"service-2": {
"version": "master"
}
}
}

因此,删除除.services.*.version之外的所有内容。请帮忙,以我对JQ的了解,我无法处理。

一般地翻译表达式.services.*.version,可以按如下方式使用tostream

reduce (tostream
| select(length==2 and
(.[0] | (.[0] == "services" and
.[-1] == "version")))) as $pv (null;
setpath($pv[0]; $pv[1]) )

使用jq的流式解析器

为了减少内存需求,您可以修改上面的解决方案,使用jq的流式解析器,或者使用上面的reduce,或者使用fromstream:

jq -n --stream -f program.jq input.json

其中program.jq包含:

fromstream(inputs
| select( if length == 2
then .[0] | (.[0] == "services" and
.[-1] == "version")
else . end ) )

.services.*.version.*

更广泛地解释.services.*.version,以便不要求路径的终端组件为.version,只需替换.[-1] == "version"带有:

index("version")

在上面。

如果您希望区分"版本";缺席或无效:

{services}
| .services |= map_values(select(has("version")) | {version} )

最新更新