Counts words in a file, outputs results in sorted form : File Commands « File Input Output « Java






Counts words in a file, outputs results in sorted form

    
// : c12:WordCount.java
// Counts words in a file, outputs results in sorted form.
// {Args: WordCount.java}
// From 'Thinking in Java, 3rd ed.' (c) Bruce Eckel 2002
// www.BruceEckel.com. See copyright notice in CopyRight.txt.

import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.io.StreamTokenizer;
import java.util.Collection;
import java.util.Iterator;
import java.util.Set;
import java.util.TreeMap;

class Counter {
  private int i = 1;

  public int read() {
    return i;
  }

  public void increment() {
    i++;
  }
}

public class WordCount1 {
  private static final String usage = "Usage: \nWordCount file\n"
      + "Counts the words in the file and "
      + "outputs results in sorted form.";

  private FileReader file;

  private StreamTokenizer st;

  // A TreeMap keeps keys in sorted order:
  private TreeMap counts = new TreeMap();

  public WordCount1(String filename) throws FileNotFoundException {
    try {
      file = new FileReader(filename);
      st = new StreamTokenizer(new BufferedReader(file));
      st.ordinaryChar('.');
      st.ordinaryChar('-');
    } catch (FileNotFoundException e) {
      throw new RuntimeException(e);
    }
  }

  public void dispose() {
    try {
      file.close();
    } catch (IOException e) {
      throw new RuntimeException(e);
    }
  }

  public void countWords() {
    try {
      while (st.nextToken() != StreamTokenizer.TT_EOF) {
        String s;
        switch (st.ttype) {
        case StreamTokenizer.TT_EOL:
          s = new String("EOL");
          break;
        case StreamTokenizer.TT_NUMBER:
          s = Double.toString(st.nval);
          break;
        case StreamTokenizer.TT_WORD:
          s = st.sval; // Already a String
          break;
        default: // single character in ttype
          s = String.valueOf((char) st.ttype);
        }
        if (counts.containsKey(s))
          ((Counter) counts.get(s)).increment();
        else
          counts.put(s, new Counter());
      }
    } catch (IOException e) {
      throw new RuntimeException(e);
    }
  }

  public Collection values() {
    return counts.values();
  }

  public Set keySet() {
    return counts.keySet();
  }

  public Counter getCounter(String s) {
    return (Counter) counts.get(s);
  }

  public static void main(String[] args) throws FileNotFoundException {
    if (args.length == 0) {
      System.out.println(usage);
      System.exit(1);
    }
    WordCount1 wc = new WordCount1(args[0]);
    wc.countWords();
    Iterator keys = wc.keySet().iterator();
    while (keys.hasNext()) {
      String key = (String) keys.next();
      System.out.println(key + ": " + wc.getCounter(key).read());
    }
    wc.dispose();
  }
} ///:~



           
         
    
    
    
  








Related examples in the same category

1.Touch: set File Last Modified Time
2.File Copy in Java with NIO
3.File Copy in Java
4.Copying a file using channels and buffers
5.Copy files using Java IO APICopy files using Java IO API
6.Mimic the Unix Grep command
7.Grep tools
8.BGrep: a regular expression search utility, like Unix grep
9.File concatenation
10.Compress files using the Java ZIP API
11.Delete file using Java IO API
12.Undent - remove leading spaces
13.TeePrintStream tees all PrintStream operations into a file, rather like the UNIX tee(1) command
14.Delete a file from within Java, with error handling
15.DirTree - directory lister, like UNIX ls or DOS and VMS dirDirTree - directory lister, like UNIX ls or DOS and VMS dir
16.Program to empty a directory
17.Report on a file's status in Java
18.Simple directory lister
19.Readonly Files
20.List root directoryList root directory
21.Rename a file in Java
22.FNFilter - directory lister using FilenameFilter
23.mkdir examples
24.Program to remove files matching a name in a directory
25.Ls directory lister modified to use FilenameFilterLs directory lister modified to use FilenameFilter
26.Move a File
27.Word Count
28.Diff: text file difference utility.Diff: text file difference utility.
29.Count chars in a File
30.Move File
31.Get file date and time
32.Return readable file size with selected value measure
33.Move a file
34.File Compressor
35.Recursive Delete File
36.Read number of lines from a File
37.Copy and overwrite files