Java基础之集合List<map>进行排序

现有以下集合List<Map<String,String>>,

集合中元素Map中主要包含“code”,“name”等属性,

要求按code升序,name降序的顺序对集合进行重新排序;

实现Collections接口进行排序

1,先根据需求封装List<Map<String,String>>

 public static void main(String[] args) {
        List<Map<String, String>> list = new ArrayList<>();
        Map<String, String> mapOne = new HashMap<>();
        mapOne.put("code", "001");
        mapOne.put("name", "小a");

        Map<String, String> mapTwo = new HashMap<>();
        mapTwo.put("code", "003");
        mapTwo.put("name", "小b");

        Map<String, String> mapThree = new HashMap<>();
        mapThree.put("code", "002");
        mapThree.put("name", "小c");
        list.add(mapOne);
        list.add(mapTwo);
        list.add(mapThree);

        //进行排序
        List<Map<String, String>> listResult = listSort(list);
        //控制台打印
        for (Map<String, String> map : listResult) {
            System.out.println("编号:" + map.get("code") + ",姓名:" + map.get("name"));
        }
    }

2,根据问题,调用Conllections方法进行两次排序

    public static List<Map<String, String>> listSort(List<Map<String, String>> list) {

        //实现Collections接口进行排序
        Collections.sort(list, new Comparator<Map<String, String>>() {
            @Override
            public int compare(Map<String, String> o1, Map<String, String> o2) {
                return o1.get("code").compareTo(o2.get("code"));
            }
        });

        //在对已经排序完成的进行降序
        Collections.sort(list, new Comparator<Map<String, String>>() {
            @Override
            public int compare(Map<String, String> o1, Map<String, String> o2) {
                return -o1.get("name").compareTo(o2.get("name"));
            }
        });


        return list;

    }

关于compareTo用法:

https://blog.csdn.net/Soinice/article/details/80662732

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要对Java中的List<Map<String, String>>进行排序,可以使用Collections.sort()方法和Comparator接口。需要在compare()方法中定义排序规则。 首先,您需要创建一个List<Map<String, String>>对象,并向其中添加Map元素。每个Map对象代表一个包含键值对的元素,其中键是"countScore",值是要排序的数字。 接下来,您可以使用Collections.sort()方法对List进行排序。在Comparator对象的compare()方法中,将比较两个Map对象的"countScore"值,以确定它们的顺序。 以下是一个示例代码片段: ``` List<Map<String, String>> list = new ArrayList<Map<String, String>>(); list.add(getData(0)); list.add(getData(7)); list.add(getData(5)); list.add(getData(6)); list.add(getData(2)); Collections.sort(list, new Comparator<Map<String, String>>() { public int compare(Map<String, String> o1, Map<String, String> o2) { String str1 = o1.get("countScore").toString(); String str2 = o2.get("countScore").toString(); return str1.compareTo(str2); } }); System.out.println("排序后:" + list); ``` 在这个示例中,我们定义了一个比较器,将两个Map对象的"countScore"值转换为字符串进行比较,并返回比较结果。最后,我们将排序后的List打印出来。 请注意,这只是一个示例代码片段,您需要根据自己的实际需求进行适当的修改和调整。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [java List<Map> 排序](https://blog.csdn.net/fragrant_no1/article/details/84109229)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [neo4j知识图谱apoc.*函数集合包扩展](https://download.csdn.net/download/wang111mo/88274716)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值