java 8 根据属性去重案列 及使用 groupingby 的排序问题

场景:excel导入,按照excel的顺序排序,需要去重并且做分组判断,

首先我们去重:

List<OrdItem> ordItems=list.stream().filter(distinctByKey(o -> o.getPnId() + ";" + o.getCondition())).collect(Collectors.toList());
                                                注明:此处list 为传入的值, distinctByKey为内部方法
public static <T> Predicate<T> distinctByKey(Function<? super T,Object> keyExtractor){
    Map<Object,Boolean> seen = new ConcurrentHashMap<>();
    return t -> seen.putIfAbsent(keyExtractor.apply(t) == null ? "null" : keyExtractor.apply(t),Boolean.TRUE) == null;
}

也可:List<OrdItem> ordItems = list.stream().collect(Collectors.collectingAndThen(Collectors. toCollection(() -> new TreeSet<>(Comparator.comparing(o -> o.getPnId() + ";" + o.getCondition()))), ArrayList::new)); 直接去重

然后我们进行分组:

首先我为改之前的代码是这样的:

ordItems.stream() .collect(Collectors.groupingBy(OrdItem::getPnId)) .entrySet().stream().forEach(entry -> {
//业务操作
}

出现的问题:原本传入的list顺序被破坏,且无序

后修改为:

ordItems.stream() .collect(Collectors.groupingBy(OrdItem::getPnId,TreeMap::new, Collectors.toList())) .entrySet().stream().forEach(entry -> {
//业务操作
}

出现问题为:原本传入的list顺序被改变,有序,且可控制升降序排序

但是这两种都不能满足我的需求:

最后改成:

ordItems.stream()
        .collect(Collectors.groupingBy(OrdItem::getPnId, LinkedHashMap::new, Collectors.toList()))
        .entrySet().stream().forEach(entry -> {//业务操作}

使用了linkedHashMap 才满足了本次需求。

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值