Stream流分组,统计,求和

Posted tubashu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Stream流分组,统计,求和相关的知识,希望对你有一定的参考价值。

public class Test {

public static void main(String[] args) {
List<OrdersDO> list = new ArrayList<>();//查询昨天一天的所有交易
OrdersDO o1 = new OrdersDO();
o1.setAppId(1L);
o1.setTradeAmount(100L);
o1.setStatus(1);
list.add(o1);
OrdersDO o2 = new OrdersDO();
o2.setAppId(5L);
o2.setTradeAmount(300L);
o2.setStatus(2);
list.add(o2);
OrdersDO o3 = new OrdersDO();
o3.setAppId(1L);
o3.setTradeAmount(100L);
o3.setStatus(3);
list.add(o3);
OrdersDO o4 = new OrdersDO();
o4.setAppId(5L);
o4.setTradeAmount(300L);
o4.setStatus(4);
list.add(o4);
OrdersDO o5 = new OrdersDO();
o5.setAppId(5L);
o5.setTradeAmount(300L);
o5.setStatus(4);
list.add(o5);
//统计每个应用实际支付总额
Map<Long, Long> tradeAmountMap = list.stream().filter(o->o.getStatus()==2)
.collect(Collectors.groupingBy(OrdersDO::getAppId,
Collectors.summingLong(OrdersDO::getTradeAmount)));
System.out.println(tradeAmountMap);

//统计每个应用取消总额
Map<Long, Long> cancelAmountMap = list.stream()
.collect(Collectors.groupingBy(OrdersDO::getAppId,
Collectors.summingLong(OrdersDO::getTradeAmount)));
System.out.println(cancelAmountMap);

//统计每个应用下交易笔数
Map<Long, Long> appTradeNum = list.stream().collect(Collectors.groupingBy(OrdersDO::getAppId, Collectors.counting()));
System.out.println(appTradeNum);

//统计每个应用每种状态下交易笔数
Map<Long, Map<Integer, Long>> tradeNumMap = list.stream().
collect(Collectors.groupingBy(OrdersDO::getAppId,
Collectors.groupingBy(OrdersDO::getStatus,
Collectors.counting())));
System.out.println(tradeNumMap);

//每个应用下交易笔数按数量排序
Map<Long,Long> finalMap = new LinkedHashMap<>();
appTradeNum.entrySet().stream().sorted(Map.Entry.<Long, Long>comparingByValue().reversed()).forEachOrdered(e->finalMap.put(e.getKey(),e.getValue()));
System.out.println(finalMap);
}
}

 

以上是关于Stream流分组,统计,求和的主要内容,如果未能解决你的问题,请参考以下文章

Stream Collectors.groupingBy的四种用法 解决分组统计(计数求和平均数等)范围统计分组合并分组结果自定义映射等问题

Java8使用Stream流实现List列表的查询统计排序分组

JDK8对List进行分组操作(stream的groupby)

利用stream对list集合中的bigdecimal进行分组求和,均值,最大值,最小值

jdk1.8中使用stream中的一些用途

stream流运算:求和(基本数据类型,BigDecimal),多字段乘积求和,提取对象属性集合