1. 程式人生 > >List集合根據Map裡某個key對List集合重新排序介紹

List集合根據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; } });