您的位置:首页 > 其它

IO流(15)--与TreeMap统计文本中每个字符出现的次数

2017-12-13 20:27 302 查看
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();
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐