如何使用 jq 将此嵌套对象转换为扁平对象?
Posted
技术标签:
【中文标题】如何使用 jq 将此嵌套对象转换为扁平对象?【英文标题】:How do I transform this nested object to a flattened object using jq? 【发布时间】:2017-12-03 19:10:58 【问题描述】:我需要使用jq
将此输入转换为非嵌套对象。在 Python 中,我可以将其正确转换如下。
output = (k1 + '-' + k2): v2 for k1, v1 in input.iteritems() for k2, v2 in v1.iteritems()
但我无法在jq
中弄清楚如何做到这一点。操作嵌套对象的文档很差。
"group1-permission":
"address": "test1",
"others": "test2",
"packet-capture": "test3",
"policy": "test4",
"schedule": "test5",
"service": "test6"
,
"group2-permission":
"config": "none",
"data-access": "none",
"report-access": "none",
"threat-weight": "none"
,
"group3-permission":
"antivirus": "none",
"application-control": "none",
"casi": "none",
"data-loss-prevention": "none",
"dnsfilter": "none",
"icap": "none",
"ips": "none",
"spamfilter": "none",
"voip": "none",
"waf": "none",
"webfilter": "none"
输出应如下所示:
"group1-permission-address": "test1",
"group1-permission-others": "test2",
"group1-permission-packet-capture": "test3",
"group1-permission-policy": "test4",
"group1-permission-schedule": "test5",
"group1-permission-service": "test6",
"group2-permission-config": "none",
"group2-permission-data-access": "none",
"group2-permission-report-access": "none",
"group2-permission-threat-weight": "none",
"group3-permission-antivirus": "none",
"group3-permission-application-control": "none",
"group3-permission-casi": "none",
"group3-permission-data-loss-prevention": "none",
"group3-permission-dnsfilter": "none",
"group3-permission-icap": "none",
"group3-permission-ips": "none",
"group3-permission-spamfilter": "none",
"group3-permission-voip": "none",
"group3-permission-waf": "none",
"group3-permission-webfilter": "none"
【问题讨论】:
【参考方案1】:在我看来,该文档非常好,但它有助于熟悉 map
并熟悉管道和过滤器。无论如何,这是一个面向地图的解决方案:
to_entries
| map( .key as $key
| .value
| to_entries
| map ( ($key + "-" + .key): .value ) | add ) | add
这是另一个,适用于任意深度嵌套的 JSON 对象和数组:
[paths(scalars) as $path | ($path|join("-")): getpath($path) ] | add
这里当然有一个警告:如果由于使用“-”作为连接字符而导致路径发生冲突,则可能会丢失一些数据。
【讨论】:
谢谢你。我头疼得厉害,而且效果很好。以上是关于如何使用 jq 将此嵌套对象转换为扁平对象?的主要内容,如果未能解决你的问题,请参考以下文章
数据格式转换js如何将对象嵌套的数组数据取出来加到对象里,数据格式转换[{[],[]},{[],[]}] 转[{},{}]