java 对 List 排序,根据 List<Map> 的 Map 里的字段

根据 List 里 Map 的一个字段进行排序

类型是:List<Map<String, Object>>

按照 List 里 Map 的一个字段进行排序:

oneList.sort(new Comparator<Map<String, Object>>() {
    @Override
    public int compare(Map<String, Object> o1, Map<String, Object> o2) {
        String day1 = (String) o1.get("day"); // day1 是从 list 中拿出的第一个 day 的值
        String day2 = (String) o2.get("day"); // day2 是从 list 中拿出的第二个 day 的值
        return day1.compareTo(day2);
    }
});

IDEA 对 new Comparator<Map<String, Object>>() 这段代码进行提示:

Anonymous new Comparator<Map<String, Object>>() can be replaced with lambda
译:匿名 new Comparator<Map<String, Object>>() 可以被 lambda 替换

自动更改后:

oneList.sort((o1, o2) -> {
    String day1 = (String) o1.get("day"); // day1 是从 list 中拿出的第一个 day 的值
    String day2 = (String) o2.get("day"); // day2 是从 list 中拿出的第二个 day 的值
    return day1.compareTo(day2);
});

倒序:如果想要倒序,更换最后一句 return 的 day1 和 day2 的位置即可。

( 2021.07.01 )

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java中,可以使用Comparator工具类对List<Map<String, Object>>进行多字段排序。下面是一个简单的示例代码: ```java import java.util.*; public class MultiFieldSort { public static void main(String[] args) { List<Map<String, Object>> list = new ArrayList<>(); // 添加示例数据 Map<String, Object> map1 = new HashMap<>(); map1.put("name", "John"); map1.put("age", 25); map1.put("score", 80); list.add(map1); Map<String, Object> map2 = new HashMap<>(); map2.put("name", "Alice"); map2.put("age", 30); map2.put("score", 90); list.add(map2); Map<String, Object> map3 = new HashMap<>(); map3.put("name", "Bob"); map3.put("age", 20); map3.put("score", 85); list.add(map3); // 按照name字段升序,age字段降序进行排序 list.sort(Comparator.comparing((Map<String, Object> m) -> (String) m.get("name")) .thenComparing(Comparator.comparingInt((Map<String, Object> m) -> (int) m.get("age")).reversed())); // 输出排序结果 for (Map<String, Object> map : list) { System.out.println(map); } } } ``` 这段代码演示了如何对List<Map<String, Object>>进行多字段排序。首先,我们创建了一个包含多个MapList,并添加了示例数据。然后,使用Comparator.comparing方法指定要排序字段,并使用thenComparing方法指定多个字段排序顺序。在示例中,我们按照name字段进行升序排序,如果name字段相同,则按照age字段进行降序排序。最后,使用List的sort方法对List进行排序,并输出排序结果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值