尝试一下:String fileName = "file.txt";
try {
Map wordCount = Files.lines(Path.of(fileName))
.flatMap(line -> Arrays.stream(line.split("\\s+")))
.filter(w->w.matches("[a-zA-Z]+"))
.sorted(paring(String::length)
.thenComparing(String.CASE_INSENSITIVE_ORDER))
.collect(Collectors.groupingBy(w -> w,
LinkedHashMap::new, Collectors.counting()));
wordCount.entrySet().forEach(System.out::println);
}catch (Exception e) {
e.printStackTrace();
}
这相对简单。它只是在空白处分割并通过将单词放入地图(其中Key是单词,而Value是包含计数的long)来对单词进行计数。
我提供了一个过滤器,仅捕获字母以外的单词。它的工作方式是将Lines放入流中。然后使用String.split将每一行拆分为多个单词。由于这会创建一个数组,因此flatMap会将所有这些单独的单词流转换为单个单词流,并在其中对其进行处理。它的作用是Collectors.groupingBy,它将为每个键以特定方式将值分组。在这种情况下,我指定了Collectors.counting()方法来增加每次出现键(即单词)时的计数。
作为一种选择,我先对单词进行长度排序,然后按字母顺序排序,忽略大小写。