java8List根据对象某个字段或多个字段去重、筛选、List转Map、排序、分组、
统计计数等等
我们利⽤ java8 的新特性,可以⽅便简洁⾼效的处理⼀些集合的数据。
简单⽰例如下:
先定义⼀个订单对象(Order)
public class Order {
private Long id;
private Long userId;
private String num;
private String type;
private Float allAmt;
private Float payAmt;
private Integer orderNum;
public Order(Long id, Long userId, String num, String type, Float allAmt, Float payAmt, Integer orderNum){
this.id = id;
this.userId = userId;
this.num = num;
this.allAmt = allAmt;
this.payAmt = payAmt;
}
//
}
过滤筛选:
List<Order> orders = wArrayList();
// 筛选总⾦额⼤于1000的订单
orders = orders.stream().filter(item -> AllAmt()>1000.00f).List());
分组:
List<Order> orders = wArrayList();
// 按照订单类型分组
Map<String, List<Order>> orderGroupMap = orders.stream().upingBy(Order::getType));
去重:
List<Order> orders = wArrayList();
// 按照订单编号去重
orders = orders.stream().Collection(()
->new TreeSet<>(Comparatorparing(Order::getNum))), ArrayList::new));
// 按照订单编号和类型去重
orders = orders.stream().Collection(()
->new TreeSet<>(Comparatorparing(o -> o.getNum()+";"+ o.getType()))), ArrayList::new));
List 转 Map :
List<Order> orders = wArrayList();
// 将订单集合转换成订单编号-应付⾦额 map,注意订单编号作为 key 不能重复,应先做去重处理
Map<String, Float> numPayMap = orders.stream().Map(Order::getNum, Order::getPayAmt));
// ⽤ id 做 key 将 List 转成 Map
Map<Long, Order> orderMap = orders.stream().Map(Order::getId, item -> item));
排序:
List<Order> orders = wArrayList();
// 按照订单总⾦额从⾼到低排序
// ⽅式⼀
orders.sort((o1, o2)java stream
-> o1.getAllAmt()== null ?1:(o2.getAllAmt()== null ?-1: o2.getAllAmt()AllAmt())));
// ⽅式⼆
orders.sort(Comparatorparing(Order::getAllAmt,(o1, o2)
-> o1 == null ?1:(o2 == null ?-1: o2pareTo(o1))));
/
/ ⽅式三 (allAmt 字段不能为 null, null 会导致排序失败)
orders.sort(Comparatorparing(Order::getAllAmt).reversed());
// 先按照订单类型排序,再按照订单应付⾦额从⾼到低排序
orders.sort(Comparatorparing(Order::getType,(o1, o2)
-> o1 == null ?1:(o2 == null ?-1: o1pareTo(o2))).thenComparing((o1, o2)
-> o1.getPayAmt()== null ?1:(o2.getPayAmt()== null ?-1: o2.getPayAmt()PayAmt()))));
统计计数:
List<Order> orders = wArrayList();
// 统计所有订单的总⾦额
// 求和
Double sum = orders.stream().filter(item -> AllAmt()!= null).mapToDouble(Order::getAllAmt).sum();
// 最⼤总⾦额
OptionalDouble max = orders.stream().filter(item -> AllAmt()!= null).mapToDouble(Order::getAllAmt).max();
// 防⽌没有订单数据的处理
Double maxAllAmt = max.isPresent()? AsDouble():0;
// 最⼩总⾦额
OptionalDouble min = orders.stream().filter(item -> AllAmt()!= null).mapToDouble(Order::getAllAmt).min();
// 平均总⾦额
OptionalDouble average = orders.stream().filter(item -> AllAmt()!= null).mapToDouble(Order::getAllAmt).average();
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论