Map 分组后根据key排序

原数据

List<Map<String, Object>> listData = userDao.getUserList(user);

1.分组

Map<String, List<Map<String, Object>>> groupByDatas = listData.stream().collect(
                Collectors.groupingBy(map -> String.valueOf(map.get("name"))));

2.排序

//排序
Map<String, List<Map<String, Object>>> result=groupByDatas.entrySet().stream().sorted((o1, o2) -> {
            try {
                String d1 = String.valueOf(o1.getKey());
                String d2 = String.valueOf(o2.getKey());
                return d1.compareTo(d2);
            } catch (Exception e) {
                e.printStackTrace();
            }
            return 0;
        }).collect(Collectors.toMap(
                Map.Entry::getKey,
                Map.Entry::getValue,
                (oldVal, newVal) -> oldVal,
                LinkedHashMap::new
        ));

3.拓展 List<User> 根据实体属性排序

3.1单个属性排序

List<UserVo> users=UserMapper.queryUsers(userDto);
users.sort((UserVo u1,UserVo u2)->u2.getAge() - u1.getAge());

3.2多个属性排序

List<UserVo> users=UserMapper.queryUsers(userDto);
Comparator<UserVo> comparator1 = (UserVo u1,UserVo u2)->u2.getAge() - u1.getAge();
Comparator<UserVo> comparator2 = comparator1.thenComparing((UserVo u1,UserVo u2) -> u2.getNumber() - u1.getNumber());
users.sort(comparator2);

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值