练习_堆文本内容进行排序

练习:
堆文本内容进行排序
按照(1,2,3,....)顺序排序
分析:
1.创建一个HashMAp集合对象,key:鵆每行文本的序号(1,2,3);value:存储每行的文本
2.创建字符缓冲输入流对象,构造方法中绑定字符输入流
3.创建字符缓冲输出流对象,构造方法中绑定字符出书刘
4.使用字符缓冲输入流的方法readLine逐行读取文本
5.堆读取到的文本进行切割,获取航中的序号和文本内容
6.吧切割好的需要和文本的内容存储到HashMap集合中(key需要是有序的,会自动排序)
7.遍历Map集合获取每一个键值对
8.把每一个键值对,拼接位一个文本行
9.把拼接好的文本,使用字符缓冲输出流中的方法write写入到文件中
10.释放资源

代码实现:

package com.yang.Test.BufferedStudy;

import java.io.*;
import java.util.HashMap;

public class Test {
    static String line;
    public static void main(String[] args) throws IOException {
        HashMap<String, String> map = new HashMap<>();
        BufferedReader br = new BufferedReader(new FileReader("Document\\in.txt"));
        BufferedWriter bw = new BufferedWriter(new FileWriter("Document\\out.txt"));


        while((line = br.readLine())!=null){
            String[] arr = line.split("\\.");
            map.put(arr[0],arr[1]);
        }

        map.forEach((k, v) -> {
            line = k+"."+v;
            try {
                bw.write(line);
                bw.newLine();
            } catch (IOException e) {
                throw new RuntimeException(e);
            }

        });



        br.close();
        bw.close();
    }
}

posted @ 2022-07-18 15:03  我滴妈老弟  阅读(21)  评论(0编辑  收藏  举报