统计一个文本中单词出现的个数(草稿版)

package testProject;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;

public class Word {
	static Map<String, Integer> sumWords(String str) {
		if (str == null)
			return null;
		str = str.trim();
		int len = str.length();
		if (len == 0)
			return null;
		Map<String, Integer> map = new HashMap<String, Integer>();
		String[] words = str.split("\\s+");
		for (int i = 0; i < words.length; i++) {
			int k = map.get(words[i]) == null ? 0 : map.get(words[i]);
			map.put(words[i], k + 1);
		}
		return map;
	}

	public static void main(String[] args) throws IOException {
		String filename = "C:\\Users\\cxb\\Desktop\\test.txt";
		FileReader fileReader = new FileReader(new File(filename));
		BufferedReader bufferedReader = new BufferedReader(fileReader);
		StringBuffer stringBuffer = new StringBuffer();
		String string = null;
		while ((string = bufferedReader.readLine()) != null) {
			stringBuffer.append(string);
		}
		String str = stringBuffer.toString();
		Map<String, Integer> map = sumWords(str);
		for (Entry<String, Integer> entry : map.entrySet()) {
			System.out.println(entry.getKey() + ":" + entry.getValue());
		}
	}
}

  

posted @ 2018-08-05 21:13  cxbit  阅读(418)  评论(0编辑  收藏  举报