如何使用 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 将此嵌套对象转换为扁平对象?的主要内容,如果未能解决你的问题,请参考以下文章

使用 JQ 展平嵌套的 Json 对象

JavaScript 扁平与树形数组数据的转换

如何按名称过滤键,然后使用 jq 访问嵌套对象

JQ 于 JS 对象之间的转化

使用 jq 为 JSON 对象的嵌套数组中的属性展平数组

数据格式转换js如何将对象嵌套的数组数据取出来加到对象里,数据格式转换[{[],[]},{[],[]}] 转[{},{}]