Day_13【IO流】扩展案例2_统计指定项目文件中字符出现的次数

需求分析

  •   统计当前项目下info2.txt文件中, 每个字符出现的个数
      文件内容如下:
      		welcome to itheima!!!
    	最终效果如下:
      		w(1) (2)!(3)t(2)e(3)c(1)a(1)o(2)l(1)m(2)h(1)i(2)
    

思路

  •  1.创建HashMap集合, 用于统计每个字符出现的次数
     2.创建输入流对象关联数据源
     3.读取到文件中的每一个字符
     4.判断字符是否是第一次出现
     	a)如果是的话, 键的位置存当前字符, 值的位置存1
     	b)如果不是第一次出现, 键的位置还是当前字符, 值的位置需要将原本记录的值取出, 然后+1存储
     5.创建字符串缓冲区(StringBuilder), 用于拼接结果
     6.将数据从集合中取出, 并拼接
     7.创建输出流对象
     8.调用write方法写出数据
     9.关闭流释放资源
    

代码

package com.itheima;

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map.Entry;

public class Test2 {
	public static void main(String[] args) throws IOException {
		//创建HashMap集合, 用于统计每个字符出现的次数
		HashMap<Character,Integer> hm = new HashMap();
		
		//创建输入流对象关联数据源
		FileInputStream fis = new FileInputStream("/Users/zhaozhuang/Downloads/develop/subject/day13-IO流/homework/day13作业答案/TestDay13/info2.txt");
		
		//读取到文件中的每一个字符
		int len;
		while((len = fis.read()) != -1) {
			char c = (char) len;
			//判断字符是否是第一次出现
			if(!hm.containsKey(c)) {
				//如果是的话, 键的位置存当前字符, 值的位置存1
				hm.put(c, 1);
			} else {
				//如果不是第一次出现, 键的位置还是当前字符, 值的位置需要将原本记录的值取出, 然后+1存储
				hm.put(c, hm.get(c) + 1);
			}
		}
		
		//创建字符串缓冲区(StringBuilder), 用于拼接结果
		StringBuilder sb = new StringBuilder();
		
		//将数据从集合中取出, 并拼接
		for(Entry<Character,Integer> en : hm.entrySet()) {
			sb.append(en.getKey()).append("(").append(en.getValue()).append(")");
		}
		
		//创建输出流对象
		FileOutputStream fos = new FileOutputStream("/Users/zhaozhuang/Downloads/develop/subject/day13-IO流/homework/day13作业答案/TestDay13/info2.txt");
		
		//调用write方法写出数据
		fos.write(sb.toString().getBytes());
		
		//释放资源
		fis.close();
		fos.close();
	}

}

原文地址:https://www.cnblogs.com/zzzsw0412/p/12772521.html