Map根据key排序

本文介绍了一种使用Java Stream API按月份将列表中的数据进行分组并排序的方法。通过`Collectors.groupingBy()`方法根据月份字段进行分组,并利用自定义比较器对分组后的Map按月份进行排序。

按月份将List进行分组,再排序

1、按月份将List进行分组

  Map<String, List<PrsCalcData>> result = data.stream().collect(Collectors.groupingBy(PrsCalcData::getSmo));

2、注意此处的key是string类型,是用于一般排序

  Map<String,List<PrsCalcData>> smoMap = result.entrySet().stream()
          .sorted(Map.Entry.comparingByKey())
          .collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue,
                 (oldValue, newValue) -> oldValue, LinkedHashMap::new));

3、注意由于,String类型的"11"比"2"大,所以需要转换一下

   Map<String,List<PrsCalcData>> smoMap = result.entrySet().stream()
          .sorted(new Comparator<Map.Entry<String, List<PrsCalcData>>>() {
            @Override public int compare(Map.Entry<String, List<PrsCalcData>> o1, Map.Entry<String, List<PrsCalcData>> o2) {
              Integer key1 = Integer.parseInt(o1.getKey());
              Integer key2 = Integer.parseInt(o2.getKey());
              return key1.compareTo(key2);
            }
          })
          .collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue,
                  (oldValue, newValue) -> oldValue, LinkedHashMap::new));
在Java中,对`Map`根据键(Key)进行排序可以通过多种方法实现。以下是几种常见的实现方式: ### 使用 `TreeMap` `TreeMap` 是一种基于红黑树的数据结构,它默认按照键的自然顺序进行排序,也可以通过自定义比较器来指定排序规则。例如: ```java Map<String, Object> sortedMap = new TreeMap<>(map); ``` 如果需要自定义排序规则,可以传递一个带有比较器的 `TreeMap` 构造函数: ```java Map<String, Object> sortedMap = new TreeMap<>(new Comparator<String>() { @Override public int compare(String o1, String o2) { return o1.compareTo(o2); } }); sortedMap.putAll(map); ``` ### 使用 `Stream API` Java 8 引入了 `Stream API`,可以通过流操作对 `Map` 的键值对进行排序。以下是一个基于键升序排序的示例: ```java Map<String, Object> sortedMap = map.entrySet() .stream() .sorted(Map.Entry.comparingByKey()) .collect(Collectors.toMap( Map.Entry::getKey, Map.Entry::getValue, (oldValue, newValue) -> oldValue, LinkedHashMap::new )); ``` ### 自定义排序实现 如果需要更复杂的排序逻辑,可以通过提取键并使用 `Arrays.sort()` 或 `Collections.sort()` 来实现自定义排序。以下是一个基于自定义比较器的实现: ```java public static String[] sortMapKey(Map<String, Object> map) { String[] keyArr = map.keySet().toArray(new String[map.size()]); Arrays.sort(keyArr, new Comparator<String>() { @Override public int compare(String o1, String o2) { return o1.compareTo(o2); } }); return keyArr; } ``` ### 使用内部类实现比较器 在某些情况下,可能需要访问 `Map` 的值来进行排序,这时可以定义一个内部类作为比较器: ```java class ComparMap implements Comparator<String> { private Map<String, Object> map; public ComparMap(Map<String, Object> map) { this.map = map; } @Override public int compare(String o1, String o2) { return ((Comparable) map.get(o1)).compareTo(map.get(o2)); } } ``` ### 示例代码 以下是一个完整的示例代码,展示如何根据键对 `Map` 进行排序: ```java import java.util.*; public class MapSortExample { public static void main(String[] args) { Map<String, Integer> map = new HashMap<>(); map.put("banana", 3); map.put("apple", 1); map.put("orange", 2); // 使用 TreeMap 进行排序 Map<String, Integer> sortedMapByTreeMap = new TreeMap<>(map); System.out.println("Sorted by TreeMap: " + sortedMapByTreeMap); // 使用 Stream API 进行排序 Map<String, Integer> sortedMapByStream = map.entrySet() .stream() .sorted(Map.Entry.comparingByKey()) .collect(Collectors.toMap( Map.Entry::getKey, Map.Entry::getValue, (oldValue, newValue) -> oldValue, LinkedHashMap::new )); System.out.println("Sorted by Stream API: " + sortedMapByStream); } } ``` ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值