2017-04-03 88 views
-2

我编写了下面的代码来回答上述问题。谁能告诉我我哪里出了问题。计算数组中每个元素出现在文件中的次数

我期望看到代码返回数组中每个元素出现在文本文件中的确切次数。不管空格,制表符,分行符等

public class counter { 
    public static void main(String[] args) throws FileNotFoundException { 
     String[] wordname; 
     wordname = new String[] {"harry","ron","george","fred"}; 
     File file = new File("file.txt"); 
     Scanner scanner = new Scanner(file); 
     for(int i=0; i < wordname.length; i++){ 
      scanner.useDelimiter(wordname[i]); 
      int occurences = 0; 
      while(scanner.hasNext()){ 
       scanner.next(); 
       occurences++; 

      } 
      System.out.println(wordname[i] + ": " + occurences); 
     } 
     scanner.close(); 

    } 
} 

输出:
哈里:6
罗恩:1
乔治:0
fred的:0

文件:
harry harry ron george harry harry harry harry har
罗恩·罗恩·罗恩·罗恩·弗雷德 弗雷德弗雷德·乔治 哈利

+0

你是什么输出?你能给个例子吗?似乎它可能只会经历一次。 –

+0

也显示文本文件中的内容。 – sbk

+0

输出: 哈里:6 罗恩:1 乔治:0 fred的:0 文件: 哈里哈里润·乔治哈里哈里 哈里哈里HAR罗恩罗恩罗恩罗恩\t \t \t fred的 fred的fred的乔治 哈里 – codepurveyor

回答

0

你应该拆分使用,而不是字和代码扫描文件多的时间,也使性能下降的空白。

所以这是好事,这样执行相同的任务:

public class Counter { 
public static void main(String[] args) throws FileNotFoundException { 
    String[] wordname; 
    wordname = new String[]{"harry", "ron", "george", "fred"}; 
    Map<String, Integer> map = new HashMap<>(); 
    for (String string : wordname) { 
     map.put(string, 0); 
    } 
    File file = new File("file.txt"); 
    Scanner scanner = new Scanner(file); 
    scanner.useDelimiter("\\s+"); 
    String word; 
    while (scanner.hasNext()) { 
     word = scanner.next(); 
     if (map.containsKey(word)) { 
      map.put(word, map.get(word) + 1); 
     } 
    } 

    for (Map.Entry<String, Integer> entry : map.entrySet()) { 
     System.out.println(entry.getKey() + ":" + entry.getValue()); 
    } 
} 
} 
0
import java.io.File; 
import java.io.FileNotFoundException; 
import java.util.Arrays; 
import java.util.Scanner; 

public class Example { 
    public static void main(String[] args) throws FileNotFoundException { 
     //read whole file to string only once 
     String fileContent = new Scanner(new File("file.txt")).useDelimiter("\\Z").next(); 
     String[] wordname = {"harry","ron","george","fred"}; 
     // filter each name and count occurrences 
     for (String name : wordname){ 
      long count = Arrays.stream(fileContent.split(" ")).filter(s -> s.equals(name)).count(); 
      System.out.println(name + " : " + count); 
     } 
    } 
} 
相关问题