java8 Stream reduce 集合分组并递减
Map<String, Object> map1 = new HashMap<>();
map1.put("dev", "fan1");
map1.put("kwh", 50d);
Map<String, Object> map2 = new HashMap<>();
map2.put("dev", "fan1");
map2.put("kwh", 50d);
Map<String, Object> map3 = new HashMap<>();
map3.put("dev", "fan3");
map3.put("kwh", 50d);
Map<String, Object> map4 = new HashMap<>();
map4.put("dev", "fan1");
map4.put("kwh", 100D);
List<Map<String, Object>> list = new ArrayList<>();
list.add(map2);
list.add(map1);
list.add(map3);
list.add(map4);
if (CollectionUtils.isNotEmpty(list)) {
List<Map<String, Object>> result = new ArrayList<>();
list.stream().collect(Collectors.groupingBy(m-> m.get("dev").toString(), Collectors.toList())).
forEach(
(id, value) -> {
//如果大于两天才会执行 按照自己的
if (value.size()>=2) {
value.stream().reduce((a, b) ->
{
Map<String, Object> map = new HashMap();
if (!b.isEmpty()) {
map.put("dev", a.get("dev").toString());
map.put("kwh", (Double) a.get("kwh") - (Double) b.get("kwh"));
}
return map;
}).ifPresent(result::add);
}
});
System.out.println(result);
}
结果: [{dev=fan1, kwh=-100.0}]
该代码示例展示了如何使用Java8的Stream API对Map集合进行分组,并根据特定条件(元素数量大于等于2)进行递减计算。首先,创建了包含多个Map对象的列表,每个Map对象包含'dev'和'kwh'键值对。然后,通过Stream的groupingBy和reduce方法,将具有相同'dev'值的Map对象分组并进行累减操作,最后将结果存入新的列表中。输出结果为 [{dev=fan1,kwh=-100.0}
639

被折叠的 条评论
为什么被折叠?



