首页 > 解决方案 > Groovy:如何通过属性将地图列表合并到单个地图,将不同的地图值组合到内部列表中

问题描述

我想将地图列表(实际上是带有 jeft join 多对多关系表的查询的结果列表)合并到一个地图中,如果它们在所有地图中都相等,则该地图将包含一个键:值对和 key:[list-of-values] 以防某个键的值不同。例如有一个地图列表:

[  
[name:john, title:senior, access:floor1],  
[name:john, title:senior, access:floor2]  
]

到地图

[name:john, title:senior, access:[floor1, floor2]]

标签: groovy

解决方案


所以给定一个地图的输入列表:

def input = [  
    [name:'john', title:'senior', access:'floor1'],  
    [name:'john', title:'senior', access:'floor2'],  
    [name:'carol', title:'senior', access:'floor2']
]

我们可以按前两个分组(同样,作为地图):

input.groupBy { [name: it.name, title: it.title] }

这给了我们:

[
    [name:john, title:senior]:[
        [name:john, title:senior, access:floor1],
        [name:john, title:senior, access:floor2]
    ],
    [name:carol, title:senior]:[
        [name:carol, title:senior, access:floor2]
    ]
]

然后我们可以以所需的输出形式收集它们,给我们:

input.groupBy { [name: it.name, title: it.title] }.collect { k, v ->
    k + [access: v.access]
}

这给出了结果:

[
    [name:john, title:senior, access:[floor1, floor2]],
    [name:carol, title:senior, access:[floor2]]
]

推荐阅读