[英]how to sort list of hashmaps
我有一个HashMap
List
,如下所示
ArrayList l = new ArrayList ();
HashMap m = new HashMap ();
m.add("site_code","AL");
m.add("site_name","Apple");
l.add(m);
m = new HashMap();
m.add("site_code","JL");
m.add("site_name","Cat");
l.add(m);
m = new HashMap();
m.add("site_code","PL");
m.add("site_name","Banana");
l.add(m)
我想基于site_name
对list
进行排序。 所以最后它会被归类为。
Apple, Banana, Cat
我正在尝试这样的事情:
Collections.sort(l, new Comparator(){
public int compare(HashMap one, HashMap two) {
//what goes here?
}
});
如果你使你的集合变得通用,它最终会看起来像这样:
Collections.sort(l, new Comparator<HashMap<String, String>>(){
public int compare(HashMap<String, String> one, HashMap<String, String> two) {
return one.get("site_name").compareTo(two.get("site_name"));
}
});
如果由于你被困在1.4或更早版本的平台上而无法使用泛型,那么你必须将get
为String
。
(另外,作为一种风格,我更喜欢将变量声明为List
和Map
而不是ArrayList
和HashMap
。但这与问题无关。)
我认为现在是思考重新设计的好时机。 从您的示例中,看起来所有对象都具有相同的两个字段 - site_name
和site_code
。 在这种情况下,为什么不定义自己的类而不是使用HashMap
?
public class Site implements Comparable<Site> {
private String site_name;
private String site_code;
// getters and setters, equals, and hashCode
public int compareTo(Site other) {
return this.site_name.compareTo(other.getSiteName);
}
}
然后你可以使用Collections.sort()
。
就像是:
String codeOne = (String)one.get("site_code");
String codeTwo = (String)two.get("site_code");
return codeOne.compareTo(codeTwo);
我没有编译或测试过这个,但它应该沿着这些方向。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.