首页 > 解决方案 > jq 按键值排序

问题描述

给定以下 JSON(为了示例而过度简化),我需要按键的值对键进行排序。在这种情况下,顺序应该是 id > name > type。

{
    "link": [{
            "attributes": [{
                    "value": "ConfigurationElement",
                    "name": "type"
                }, {
                    "value": "NAME1",
                    "name": "name"
                }, {
                    "value": "0026a8b4-ced6-410e-9213-e3fcb28b3aab",
                    "name": "id"
                }
            ],
            "href": "href1",
            "rel": "down"
        }, {
            "attributes": [{
                    "value": "0026a8b4-ced6-410e-9213-k23g15h2u1l5",
                    "name": "id"
                }, {
                    "value": "ConfigurationElement",
                    "name": "type"
                }, {
                    "value": "NAME2",
                    "name": "name"
                }
            ],
            "href": "href2",
            "rel": "down"
        }
    ],
    "total": 2
}

预期结果:

{
    "link": [{
            "attributes": [{
                    "value": "0026a8b4-ced6-410e-9213-e3fcb28b3aab",
                    "name": "id"
                }, {
                    "value": "NAME1",
                    "name": "name"
                }, {
                    "value": "ConfigurationElement",
                    "name": "type"
                }
            ],
            "href": "href1",
            "rel": "down"
        }, {
            "attributes": [{
                    "value": "0026a8b4-ced6-410e-9213-k23g15h2u1l5",
                    "name": "id"
                }, {
                    "value": "NAME2",
                    "name": "name"
                }, {
                    "value": "ConfigurationElement",
                    "name": "type"
                }
            ],
            "href": "href2",
            "rel": "down"
        }
    ],
    "total": 2
}

如果有人能帮助我,我将不胜感激。我用 -S 和 -s 用 sort_by() 尝试了 jq,但是这个例子太复杂了,我无法根据我目前对 jq 的经验来弄清楚。十分感谢!

标签: jsonsortingkeyjq

解决方案


你可以做:

jq '.link[].attributes|=sort_by(.name)'

获取与 匹配的|=所有路径.link[].attributes,即每个“属性”数组,并将过滤器应用于每个路径sort_by(.name),其他所有内容保持不变。


推荐阅读