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();
} }
上一篇:Day_14【IO流】扩展案例2_缓冲字符输出、输入流进行用户名的创建


下一篇:2018DDCTF Misc部分WP