对文本的内容进行排序

package File02;

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

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

    //1.创建一个HashMap的集合对象,可以存储每行文本的序号(1,2,3);value:存储每行的文本。即存储一个键值对。这里要借助HashMap。
    HashMap<String,String> map=new HashMap<>();
    //2.创建字符缓冲输入流对象,构造方法中绑定字符输入流。即先输入文本内容
    BufferedReader br=new BufferedReader(new FileReader("D:\\code\\Dev-Cpp\\a.txt"));
    //3.创建字符缓冲输出流对象,构造方法中绑定字符输出输出流。即对把处理后的文本保存到哪里去。
    BufferedWriter bw=new BufferedWriter(new FileWriter("D:\\code\\Dev-Cpp\\out.txt"));
    //4.使用字符缓冲输入流中的办法readline,逐行读取文本。
    String line;
    //这里的null是先参考输出结果,自己不想要这个结果就把它作为限制条件。很巧妙。尤其是这个“!”非
    //有个疑问,就是当每个序号的句子跨越两行的时候,这个过程是怎么处理的。
    
    while((line=br.readLine())!=null){
        //5.对读取的文本进行切割,获取行中的序号和文本内容
        //前面的序号放在arr[0]中,.后面的内容放在arr[1]中
        String[] arr=line.split("\\.");//这个是字符串数组
        //6.把切割好的序号和文本内容存储到HashMap集合中(key是有序的,会自动排序1,2,3,)
        map.put(arr[0],arr[1]);//这个循环就不断地向map中写入键对。
    }
    //7.遍历HashMap集合,获取每一个键值对
    for (String key : map.keySet()) {
        String value=map.get(key);
        //8.把每一个键值对,拼接成一个文本行
        line=key+","+value;
        //9.把拼接好的文本,使用字符缓冲输出流中的办法write,写入到文件中
        bw.write(line);
        bw.newLine();

    }
    //10.释放资源
    bw.close();
    br.close();
}

}
很认真写的一次博客

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值