Java8 lambda如何对Map的集合按照Key进行分组并将Value求和?由于业务中遇到了这样的场景,想通过简单的方式进行求和统计,于是借助lambda表达式进行实现,下边是示例的代码:
import java.util.*;
import java.util.stream.Collectors;
public class MapMergeExample {
public static void main(String[] args) {
List<Map<String, Long>> mapList = new ArrayList<>();
Map<String, Long> map1 = new HashMap<>();
map1.put("key1", 10L);
map1.put("key2", 20L);
mapList.add(map1);
Map<String, Long> map2 = new HashMap<>();
map2.put("key2", 30L);
map2.put("key3", 40L);
mapList.add(map2);
Map<String, Long> result = mergeMaps(mapList);
System.out.println(result);
}
public static Map<String, Long> mergeMaps(List<Map<String, Long>> mapList) {
return mapList.stream()
.flatMap(map -> map.entrySet().stream())
.collect(Collectors.groupingBy(
Map.Entry::getKey,
Collectors.summingLong(Map.Entry::getValue)
));
}
}
首先将所有Map对象的键值对使用flatMap展开成一个流,然后使用Collectors.groupingBy对相同的键进行分组,并使用Collectors.summingLong计算相同键的值之和。