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();
}
}
很认真写的一次博客