JAVA基础(字符流获取文本上字符出现的次数)

1,获取文本上字符出现的次数

  • 获取一个文本上每个字符出现的次数,将结果写在times.txt上

 

【1】实现1:

import java.io.BufferedReader;

import java.io.BufferedWriter;

import java.io.FileNotFoundException;

import java.io.FileReader;

import java.io.FileWriter;

import java.io.IOException;

import java.util.HashMap;



public class Test2 {

    /**

     * @param args

     * 获取一个文本上每个字符出现的次数,将结果写在times.txt上

     *

     * 1,创建带缓冲区的输入流对象

     * 2,创建双列集合对象,目的是把字符当作键,把字符出现的次数当作值

     * 3,通过读取不断向集合中存储,存储的时候要判断,如果不包含这个键就将键和值为1存储,如果包含就将键和值加1存储

     * 4,关闭输入流

     * 5,创建输出流对象

     * 6,将结果写出

     * 7,关闭输出流

     * @throws IOException

     */

    public static void main(String[] args) throws IOException {

        //1,创建带缓冲区的输入流对象

        BufferedReader br = new BufferedReader(new FileReader("zzz.txt"));

        //2,创建双列集合对象,目的是把字符当作键,把字符出现的次数当作值

        HashMap<Character, Integer> hm = new HashMap<>();

        //3,通过读取不断向集合中存储,存储的时候要判断,如果不包含这个键就将键和值为1存储,如果包含就将键和值加1存储

        int c;

        while((c = br.read()) != -1) {

            char ch = (char)c;

            /*if(!hm.containsKey(ch)) {

                hm.put(ch, 1);

            }else {

                hm.put(ch, hm.get(ch) +  1);

            }*/

            

            hm.put(ch, !hm.containsKey(ch)? 1 : hm.get(ch) + 1);

        }

        //4,关闭输入流

        br.close();

        //5,创建输出流对象

        BufferedWriter bw = new BufferedWriter(new FileWriter("times.txt"));

        //6,将结果写出

        

        for (Character key : hm.keySet()) {

            bw.write(key + "=" + hm.get(key));

        }

        bw.close();

    }

}

 

【2】实现2

import java.io.BufferedReader;

import java.io.BufferedWriter;

import java.io.FileNotFoundException;

import java.io.FileReader;

import java.io.FileWriter;

import java.io.IOException;

import java.util.TreeMap;





public class Test3 {





    /**

     * 获取一个文本上每个字符出现的次数,将结果写在times.txt上

     *

     * 分析:

     * 1,创建带缓冲的输入流对象

     * 2,创建双列集合对象TreeMap

     * 3,将读到的字符存储在双列集合中,存储的时候要做判断,如果不包含这个键,就将键和1存储,如果包含这个键,就将该键和值加1存储

     * 4,关闭输入流

     * 5,创建输出流对象

     * 6,遍历集合将集合中的内容写到times.txt中

     * 7,关闭输出流

     * @throws IOException

     */

    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;                    //强制类型转换

            /*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("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
发出的红包

打赏作者

兴帅_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值