获取一个文本上每个字符出现的次数,将结果写在times.txt中
一、步骤:
- 创建带缓冲的输入流对象
- 创建双列集合 TreeMap
- 把读取的字符存储在双列集合中
- 关闭输入流
- 创建带缓冲的输出流对象
- 把双列集合的内容写到times.txt
- 关闭输出流
二、实现
try {
// 1、创建带缓冲的输入流对象
BufferedReader br = new BufferedReader(new FileReader("more.txt"));
// 2、创建双列集合 TreeMap
TreeMap<Character, Integer> tm = new TreeMap<>();
// 3、把读取的字符存储在双列集合中
int ch;
while ((ch = br.read()) != -1) {
char c = (char)ch; // 强制类型转换
tm.put(c, tm.containsKey(c) ? (tm.get(c) + 1) : 1);
}
// 4、关闭输入流
br.close();
// 5、创建带缓冲的输出流对象
BufferedWriter bw = new BufferedWriter(new FileWriter("times.txt"));
// 6、把双列集合的内容写到times.txt
for (Character key : tm.keySet()) {
switch (key) {
case '\t':
bw.write("\\t" + "=" + tm.get(key));
break;
case '\n':
bw.write("\\n" + "=" + tm.get(key));
break;
case '\r':
bw.write("\\r" + "=" + tm.get(key));
break;
case ' ':
bw.write("空格" + "=" + tm.get(key));
break;
default:
bw.write(key + "=" + tm.get(key));
break;
}
bw.newLine();
}
// 7、关闭输出流
bw.close();
} catch (IOException e) {
e.printStackTrace();
}