package com.fenqing.stream;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.TreeMap;
public class test {
/**
* 获取一个文本上每个字符出现的次数,将结果写在time.txt上
*/
public static void main(String[] args) throws IOException {
//1创建带缓冲的输入流对象
BufferedReader br=new BufferedReader(new FileReader("zz.txt"));
//2创建双列集合对象TreeMap
TreeMap<Character,Integer> tm=new TreeMap<Character,Integer>();
//3将读到的字符存储在双列集合中,存储的时候要做判断,如果不包括这个键,就将健和1存储,如果包含这个键,就将该健和值加1存储
int ch;
while((ch=br.read())!=-1){
char c=(char)ch; //强制类型转换
/*if(!tm.containsKey(c)){
tm.put(c, 1);
}else{
tm.put(c, tm.get(c)+1);
}*/
tm.put(c, !tm.containsKey(c)?1:tm.get(c)+1); //优化
}
//4关闭输入流
br.close();
//5创建输出流对象
BufferedWriter bw=new BufferedWriter(new FileWriter("time.txt"));
//6遍历集合,将集合中的内容写到time.txt中
/*for (Character key : tm.keySet()) {
bw.write(key+"="+tm.get(key));
bw.newLine();
}*/
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;
default:
bw.write(key+"="+tm.get(key));break;
}
bw.newLine();
}
//7关闭输出流
bw.close();
}
}
IO流(15)--与TreeMap统计文本中每个字符出现的次数
最新推荐文章于 2021-03-12 16:33:55 发布