我有兴趣将以下代码变成更简洁的代码:
final String[] strings = {"a", "B", "A", "á", "Á"};
final Collator collator = Collator.getInstance(Locale.FRANCE);
collator.setStrength(Collator.PRIMARY);
final Map<String, Set<String>> m = new TreeMap<>(collator);
for (String s : strings) {
m.compute(s, (k, v) -> {
if (v == null)
v = new TreeSet<String>();
v.add(s);
return v;
});
}
final Collection<Set<String>> requiredResult = m.values();
requiredResult.forEach(System.out::println);
输出:
[A, a, Á, á]
[B]
基本上,它的作用是通过忽略大小写和变音标记来将字母视为相等,并将这些“相等”字母分组在一起。 (顺便说一句,我知道大多数语言如果变音符号不同,则不会认为字母相等;这只是一个人为的示例。)
我正在考虑通过使用流来缩短它。但是,groupingBy
收集器要求按字母对事物进行分组。我这里没有特定的字母,只有一个 Comparator
(整理器)。
最佳答案
也许这样:
final String[] strings = {"a", "B", "A", "á", "Á"};
final Collator collator = Collator.getInstance(Locale.FRANCE);
collator.setStrength(Collator.PRIMARY);
Collection<Set<String>> result = Arrays.stream(strings)
.collect(Collectors.groupingBy(collator::getCollationKey, Collectors.toSet()))
.values();
System.out.println(result); //[[a, A, á, Á], [B]]
关于Java 8 流分组通过使用比较器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45978755/