【发布时间】:2019-11-27 12:29:10
【问题描述】:
我基本上想对地图进行分组,我必须按汽车和颜色分组并将其价格相加,如果任何组价格大于25,则按汽车,颜色和电机将结果分组并乘以总和* 3,首先部分已完成,但我被困在第二组:
def row1 = ["car":'A',"color":'B',"motor":'C', "price": 12]
def row2 = ["car":'A',"color":'B',"motor":'C', "price": 12]
def row3 = ["car":'A',"color":'B',"motor":'D', "price": 2]
def row4 = ["car":'B',"color":'B',"motor":'D', "price": 13]
def arrayRows = []
arrayRows.add(row1)
arrayRows.add(row2)
arrayRows.add(row3)
arrayRows.add(row4)
println(arrayRows) //[[car:A, color:B, motor:C, price:12], [car:A, color:B, motor:C, price:12], [car:A, color:B, motor:D, price:2], [car:B, color:B, motor:D, price:13]]
def groups = arrayRows.groupBy {row -> [Car:row.car, Color:row.color] }.collect{k , v ->
[
car:k.Car,
color:k.Color,
motor:v.motor,
price:v.collect { it.price }.sum()
]
}
println(groups) //[[car:A, color:B, motor:[C, C, D], price:26], [car:B, color:B, motor:[D], price:13]]
for(group in groups){
if (group.price > 25){ //26>25
println group //[car:A, color:B, motor:[C, C, D], price:26]
//def groupByCarColorMotor = arrayRows.groupBy {[Car: group.car, Color: group.color, Motor:?]} | Must group by car, color and motor, and multiply * 3 it's price but since motor is an array, I'm not sure how to do so, I've tried groupBy { row -> group.it.motor} etc
}
}
如果我有以下情况,我应该如何进行第二次分组: [车:A,颜色:B,电机:[C,C,D] 我应该按以下方式分组: [车:A,颜色:B,马达:C] 和 [汽车:A,颜色:B,电机:D]
预期的输出应该是: [ ["car":'A',"color":'B',"motor":'C', "price": 72, ["car":'A',"color":'B',"电机”:'D',“价格”:6]]
编辑; 我几乎设法做到了,问题是我得到了一组地图数组,而且你可能也会明白它背后的想法。
def arrayRows = [
["car":'A',"color":'B',"motor":'C', "price": 12],
["car":'A',"color":'B',"motor":'C', "price": 12],
["car":'A',"color":'B',"motor":'D', "price": 2],
["car":'B',"color":'B',"motor":'D', "price": 13]
]
println(arrayRows) //[[car:A, color:B, motor:C, price:12], [car:A, color:B, motor:C, price:12], [car:A, color:B, motor:D, price:2], [car:B, color:B, motor:D, price:13]]
def groups = arrayRows.groupBy {row -> [Car:row.car, Color:row.color] }.collect{k , v ->
[
car:k.Car,
color:k.Color,
price:v.collect { it.price }.sum()
]
}.findAll{it.price > 25}
def groupByCarColor = []
for (group in groups){
groupByCarColor.add(arrayRows.findAll{ row -> row.car == group.car && row.color == group.color}.groupBy {row -> [Car:group.car, Color:group.color, Motor:row.motor] }.collect{k , v ->
[
car:k.Car,
color:k.Color,
motor:k.Motor,
price:v.collect { it.price }.sum()*3
]
})
}
输出:[[[汽车:A,颜色:B,电机:C,价格:72],[汽车:A,颜色:B,电机:D,价格:6]]]
【问题讨论】:
-
价格总和不超过 25 的组的结果是什么?
-
@cfrick 我们不应该在第二组部分考虑这些。如果没有,输出应该是一个空数组。这会发生在 ["car":'B',"color":'B',"motor":'D', "price": 13] 因为所有汽车的价格和颜色(B,B ) 总和不要超过 25。
标签: dictionary groovy collections