//根据截单时间和订单类型分组后,分别对其他三项求和
if (CollectionUtils.isNotEmpty(orders)) {
orders = orders.stream().collect(Collectors.groupingBy(e -> e.get("deliverHmTime") + "_" + e.get("orderType"))).values().stream().map(d -> {
Map<String, Object> sampleData = d.get(0);
sampleData.put("cnt", d.stream().map(s -> new BigDecimal(s.get("cnt").toString())).reduce(BigDecimal.ZERO, BigDecimal::add));
sampleData.put("totalKind", d.stream().map(s -> new BigDecimal(s.get("totalKind").toString())).reduce(BigDecimal.ZERO, BigDecimal::add));
sampleData.put("totalQty", d.stream().map(s -> new BigDecimal(s.get("totalQty").toString())).reduce(BigDecimal.ZERO, BigDecimal::add));
return sampleData;
}).collect(Collectors.toList());
}
以上orders的定义类型为:
List<Map<String, Object>> orders = new ArrayList<>();
最后
以上就是安详短靴最近收集整理的关于【项目实战】- java 8 stream 处理对于 List<Map<String,Object>> 数据的分组求和的全部内容,更多相关【项目实战】-内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复