对Map的列表进行排序<string,string =“”> </string,>

时间:2011-03-01 14:39:09

标签: java android sorting

我有一个像这样创建的列表变量:

List<Map<String, String>> list = new ArrayList<Map<String, String>>();

在我的Android应用程序中,此列表已填充。

只是一个例子:

Map<String, String> map1 = new HashMap<String, String>();
map.put("name", "Josh");
...

Map<String, String> map2 = new HashMap<String, String>();
map.put("name", "Anna");
...

Map<String, String> map3 = new HashMap<String, String>();
map.put("name", "Bernie");
...

list.add(map1);
list.add(map2);
list.add(map3);

我正在使用list通过扩展ListView并实施各种方法来在BaseAdapter中显示结果。

我的问题:我需要根据地图的键名称

按字母顺序对list进行排序

问题:根据地图的键名称按字母顺序对list进行排序的简单方法是什么?

我似乎无法绕过这个。我已将每个Map中的每个名称提取到String数组中,并对其进行排序(Arrays.sort(strArray);)。但这并没有保留每个Map中的其他数据,所以我不太确定如何保留其他映射值

9 个答案:

答案 0 :(得分:34)

以下代码完美无缺

public Comparator<Map<String, String>> mapComparator = new Comparator<Map<String, String>>() {
    public int compare(Map<String, String> m1, Map<String, String> m2) {
        return m1.get("name").compareTo(m2.get("name"));
    }
}

Collections.sort(list, mapComparator);

但是你的地图应该是特定类的实例。

答案 1 :(得分:6)

你应该实现一个Comparator<Map<String, String>>,它基本上从它传递的两个地图中提取“name”值,然后比较它们。

然后使用Collections.sort(list, comparator)

您确定Map<String, String>确实是您列表中最好的元素类型吗?也许你应该有另一个包含一个Map<String, String>但又有getName()方法的类?

答案 2 :(得分:6)

@Test
public void testSortedMaps() {
    Map<String, String> map1 = new HashMap<String, String>();
    map1.put("name", "Josh");

    Map<String, String> map2 = new HashMap<String, String>();
    map2.put("name", "Anna");

    Map<String, String> map3 = new HashMap<String, String>();
    map3.put("name", "Bernie");

    List<Map<String, String>> mapList = new ArrayList<Map<String, String>>();
    mapList.add(map1);
    mapList.add(map2);
    mapList.add(map3);

    Collections.sort(mapList, new Comparator<Map<String, String>>() {
        public int compare(final Map<String, String> o1, final Map<String, String> o2) {
            return o1.get("name").compareTo(o2.get("name"));
        }
    });

    Assert.assertEquals("Anna", mapList.get(0).get("name"));
    Assert.assertEquals("Bernie", mapList.get(1).get("name"));
    Assert.assertEquals("Josh", mapList.get(2).get("name"));

}

答案 3 :(得分:4)

您需要创建一个比较器。我不确定为什么每个值都需要自己的映射,但这是比较器的样子:

class ListMapComparator implements Comparator {
    public int compare(Object obj1, Object obj2) {
         Map<String, String> test1 = (Map<String, String>) obj1;
         Map<String, String> test2 = (Map<String, String>) obj2;
         return test1.get("name").compareTo(test2.get("name"));
    }
}

您可以通过以下方式看到它与上述示例一起使用:

public class MapSort {
    public List<Map<String, String>> testMap() {
         List<Map<String, String>> list = new ArrayList<Map<String, String>>();
         Map<String, String> myMap1 = new HashMap<String, String>();
         myMap1.put("name", "Josh");
         Map<String, String> myMap2 = new HashMap<String, String>();
         myMap2.put("name", "Anna");

         Map<String, String> myMap3 = new HashMap<String, String>();
         myMap3.put("name", "Bernie");


         list.add(myMap1);
         list.add(myMap2);
         list.add(myMap3);

         return list;
    }

    public static void main(String[] args) {
         MapSort ms = new MapSort();
         List<Map<String, String>> testMap = ms.testMap();
         System.out.println("Before Sort: " + testMap);
         Collections.sort(testMap, new ListMapComparator());
         System.out.println("After Sort: " + testMap);
    }
}

你会有一些类型安全警告,因为我并不担心这些。希望有所帮助。

答案 4 :(得分:1)

如果您想使用lamdas并使其更容易阅读

  List<Map<String,String>> results;

  Comparator<Map<String,String>> sortByName = Comparator.comparing(x -> x.get("Name"));

  public void doSomething(){
    results.sort(sortByName)
  }

答案 5 :(得分:0)

try {
        java.util.Collections.sort(data,
                new Comparator<Map<String, String>>() {
                    SimpleDateFormat sdf = new SimpleDateFormat(
                            "MM/dd/yyyy");

                    public int compare(final Map<String, String> map1,
                            final Map<String, String> map2) {
                        Date date1 = null, date2 = null;
                        try {
                            date1 = sdf.parse(map1.get("Date"));
                            date2 = sdf.parse(map2.get("Date"));
                        } catch (ParseException e) {
                            e.printStackTrace();
                        }
                        if (date1.compareTo(date2) > 0) {
                            return +1;
                        } else if (date1.compareTo(date2) == 0) {
                            return 0;
                        } else {
                            return -1;
                        }
                    }
                });

    } catch (Exception e) {

    }

答案 6 :(得分:0)

完全没有主题
这是一个用于观看共享偏好的小工具 基于上面的答案
可能对某些人有帮助

@SuppressWarnings("unused")
public void printAll() {
    Map<String, ?> prefAll = PreferenceManager
        .getDefaultSharedPreferences(context).getAll();
    if (prefAll == null) {
        return;
    }
    List<Map.Entry<String, ?>> list = new ArrayList<>();
    list.addAll(prefAll.entrySet());
    Collections.sort(list, new Comparator<Map.Entry<String, ?>>() {
        public int compare(final Map.Entry<String, ?> entry1, final Map.Entry<String, ?> entry2) {
            return entry1.getKey().compareTo(entry2.getKey());
        }
    });
    Timber.i("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");
    Timber.i("Printing all sharedPreferences");
    for(Map.Entry<String, ?> entry : list) {
        Timber.i("%s: %s", entry.getKey(), entry.getValue());
    }
    Timber.i("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");
}

答案 7 :(得分:0)

这不是您问题的真正答案,但我需要按值的属性对地图列表进行排序,这也适用于您的情况:

Map sortedListOfMaps = someListOfMaps.sorted(Comparator.comparing(map -> ((String) map.get("someKey")))).collect(Collectors.toList()))

答案 8 :(得分:0)

有很多解决方法。下面给出了使用Java 8解决的最简单方法之一:

根据您的要求,根据地图的键名按字母顺序排序

第一种方式:

list = list.stream()
           .sorted((a,b)-> (a.get("name")).compareTo(b.get("name")))
           .collect(Collectors.toList());

或者,

list = list.stream()
           .sorted(Comparator.comparing(map->map.get("name")))
           .collect(Collectors.toList());

第二种方式:

Collections.sort(list, Comparator.comparing(map -> map.get("name")));

第三种方式:

list.sort(Comparator.comparing(map-> map.get("name")));