zoukankan      html  css  js  c++  java
  • List<Map>集合根据Map里某个key对List集合重新排序介绍

    例1:List集合数据参考形式如下:

    [{GLXXLX=03,GLXXBH=20160226105812003},{GLXXLX=01,GLXXBH=20160226105812001},{GLXXLX=02,GLXXBH=20160226105812002}]

    现在想按照GLXXLX从大到小或者从小到大进行排序,做法如下:

    //对list进行重新按照glxxlx进行升序-从小到大
    if (null != list&& list.size()>0) {
            Collections.sort(list,new Comparator<Map>() {
            @Override
            public int compare(Map o1, Map o2) {
                int ret = 0;
                //比较两个对象的顺序,如果前者小于、等于或者大于后者,则分别返回-1/0/1
                ret = o1.get("GLXXLX").toString().compareTo(o2.get("GLXXLX").toString());//逆序的话就用o2.compareTo(o1)即可
                return ret;
            }
        }); 
    }
    

      

    例2:List集合数据参考形式如下:

    [{TIME=20160221,CONTENT=测试内容1},{TIME=20160222,CONTENT=测试内容2},{TIME=20160223,CONTENT=测试内容3}]

    现在想按照时间TIME降序,将最新的时间放在前面,做法如下:

    //对sjzList 进行重新按照time进行降序排列
      if (null != sjzList && sjzList.size()>0) {
       final SimpleDateFormat df = new SimpleDateFormat("yyyyMMdd");
       Collections.sort(sjzList,new Comparator<Map>() {
        @Override
        public int compare(Map o1, Map o2) {
         int ret = 0;
         try {
          //比较两个对象的顺序,如果前者小于、等于或者大于后者,则分别返回-1/0/1
          ret = df.parse(o2.get("TIME").toString()).compareTo(df.parse(o1.get("TIME").toString()));
         } catch (ParseException e) {
          e.printStackTrace();
         }
         return ret;
        }
       });
    

      

  • 相关阅读:
    51. (转) Android学习路线
    Java字符串操作汇总
    49.Android中线程同步异步方式小结
    (转) Java多线程同步与异步
    (转) 40个Java多线程问题总结
    48.Android中android studio导入ApiDemos 问题小结
    47.Android View的加载过程 (转)
    46.Android View绘制过程 (转)
    45.Android 第三方开源库收集整理(转)
    三级联动
  • 原文地址:https://www.cnblogs.com/yangyang2018/p/7667578.html
Copyright © 2011-2022 走看看