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计算相同键的值之和。