JAVA实现获取文本上字符出现的次数

本博客介绍了一种使用Java编程语言统计文件中字符出现频率的方法。通过BufferedReader读取文件,利用TreeMap存储字符及其出现次数,最后将结果写入另一个文件。此方法适用于需要分析文本文件字符分布的场景。
public static void main(String[] args) throws IOException {
   //1,创建带缓冲的输入流对象
   BufferedReader br = new BufferedReader(new FileReader("zzz.txt"));
   //2,创建双列集合对象TreeMap
   TreeMap<Character, Integer> tm = new TreeMap<>();
   //3,将读到的字符存储在双列集合中,存储的时候要做判断,如果不包含这个键,就将键和1存储,如果包含这个键,就将该键和值加1存储
   int ch;
   while((ch = br.read()) != -1) {
      char c = (char)ch;             //强制类型转换
      tm.put(c, !tm.containsKey(c) ? 1 : tm.get(c) + 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;
      default:
         bw.write(key + "=" + tm.get(key));           //写出键和值
         break;
      }
      bw.newLine();
   }
   //7,关闭输出流
   bw.close();
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值