我使用Collator对一组对象进行排序。但我发现它像正常的一样对待重音字母:
Aktivierung
Änderung
Auszahlung
Bar
相反,我希望有这个
Aktivierung
Auszahlung
Änderung
Bar
重音字母应放在正常字母之后。这也适用于o /ö和u /ü。
Collator collator = Collator.getInstance(Locale.GERMAN);
...
private void sortDocumentiByCategoria(final Collator collator, List<ListDocumenti> listDocumenti) {
Collections.sort(listDocumenti, new Comparator<ListDocumenti>(){
@Override
public int compare(ListDocumenti arg0, ListDocumenti arg1) {
return collator.compare(arg0.getDescrizione(), arg1.getDescrizione());
}
});
}
答案 0 :(得分:0)
你的排序比你需要的更复杂......
Collections.sort会将变音符号带到最后
List<String> l = Arrays.asList("Aktivierung", "Änderung", "Auszahlung", "Bar");
System.out.println(l);
Collections.sort(l);
System.out.println(l);
[Aktivierung,Änderung,Auszahlung,Bar]
[Aktivierung,Auszahlung,Bar,Änderung]
“编辑:
根据您自己定义的德国规则实施一个整理器......
List<String> l = Arrays.asList("Aktivierung", "Änderung", "Auszahlung", "Bar");
String germanRules = "< A < a < Ä < ä < O < o < Ö < ö < U < u < Ü < ü";
RuleBasedCollator ruleBasedCollator = new RuleBasedCollator(germanRules);
Collections.sort(l, ruleBasedCollator);
System.out.println(l);
输出将是:
Aktivierung,Auszahlung,Änderung,Bar
答案 1 :(得分:0)
花了一段时间,但我发现了。你走了!
public static void main(String[] args) throws IOException {
List<String> list = Arrays.asList("Änderung", "Aktivierung", "Auszahlung", "Bar");
Collections.sort(list, createCollator());
System.out.println(list);
}
private static RuleBasedCollator createCollator() {
String german = "" +
"= '-',''' " +
"< A< a< ä< Ä< B,b< C,c< D,d< E,e< F,f< G,g< H,h< I,i< J,j" +
"< K,k< L,l< M,m< N,n< O< o< Ö< ö< P,p< Q,q< R,r< S,s< T,t" +
"< U< u< Ü< ü< V,v< W,w< X,x< Y,y< Z,z" +
"& ss=ß";
try {
return new RuleBasedCollator(german);
} catch (ParseException e) {
throw new RuntimeException(e);
}
}
测试它会产生以下结果:
>> [Aktivierung, Auszahlung, Änderung, Bar]