如何解决使用通过命令行传递的路径访问 JQ 中的嵌套值
如何或是否可以从指定路径作为命令参数的 JSON 结构中提取数据。为了简单起见,我从一些较大的脚本中获取了这个简单的片段,但在解决过程中遇到了问题:
#!/bin/bash
DATA='{
"level1": {
"level2": {
"level3": {
"foo": "bar","bar": "baz","baz": "bar"
}
}
}
}'
field="level1.level2.level3"
# does not work
jq -r --arg f ${field} '.[$f] | to_entries | .[] | "\"" + .key + "\"=\"" + .value + "\""' <<< ${DATA}
# works
jq -r --arg f ${field} '.level1.level2.level3 | to_entries | .[] | "\"" + .key + "\"=\"" + .value + "\""' <<< ${DATA}
# also works
field2="level3"
jq -r --arg f ${field2} '.level1.level2 | .[$f] | to_entries | .[] | "\"" + .key + "\"=\"" + .value + "\""' <<< ${DATA}
给出以下输出:
user@astra:~/test$ ./jqtest
jq: error (at <stdin>:12): null (null) has no keys
"foo"="bar"
"bar"="baz"
"baz"="bar"
"foo"="bar"
"bar"="baz"
"baz"="bar"
我做错了什么?
解决方法
在这种情况下,.[$f]
表示“返回与名为 level1.level2.level3
的键关联的值”。见:
$ jq --arg f 'level1.level2.level3' '.[$f]' <<< '{ "level1.level2.level3": "foo" }'
"foo"
除非任何路径组件包含一个点,否则用点分割 $f
并将结果用作 getpath
的参数应该可以工作。
getpath($f / ".")
,
jq 似乎对输入参数中的路径很挑剔。
一种解决方案是将路径作为 json 数组提供,然后使用 getpath
将其转换为路径:
field='["level1","level2","level3"]'
jq -r --argjson f "$field" 'getpath($f)' <<< ${DATA}
或者针对您的具体问题:
field='["level1","level3"]'
jq -r --argjson f "${field}" 'getpath($f) | to_entries | .[] | "\"" + .key + "\"=\"" + .value + "\""' <<< ${DATA}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。