案例:
package Buffered;
import java.io.*;
import java.util.HashMap;
/*
练习:
对文本中的内容进行排序
按照(1,2,3...)顺序排序
分析:
1.创建一个HashMap集合对象,可以:存储每行文本的序号(1,2,3...);value:存储每行的文本
2.创建字符缓冲输入流对象,构造方法中绑定字符输入法
3.创建字符缓冲输出流对象,构造方法中绑定字符输出流
4.使用字符缓冲输入流中的方法readLine,逐行读取文本
5.对读取到的文本进行切割,获取行中的序号和文本内容
6.把切割好的序号和文本内容存储到HashMap集合中(key序号是有序的,会自动排序1,2,3...)
7.遍历HashMap集合,获取每一个键值对
8.把每一个键值对,拼接为一个文本行
9.把音节好的文本,使用字符缓冲输出流中的方法write,写入到文件中
10.释放资源
*/
public class Demo02Text {
public static void main(String[] args) throws IOException {
//1.创建一个HashMap集合对象,可以:存储每行文本的序号(1,2,3...);value:存储每行的文本
HashMap<String,String> map = new HashMap<>();
//2.创建字符缓冲输入流对象,构造方法中绑定字符输入法
BufferedReader br = new BufferedReader(new FileReader("G:\\Demo02\\src\\int.txt"));
//3.创建字符缓冲输出流对象,构造方法中绑定字符输出流
BufferedWriter bw = new BufferedWriter(new FileWriter("G:\\Demo02\\src\\out.txt"));
//4.使用字符缓冲输入流中的方法readLine,逐行读取文本
String line;
while ((line = br.readLine()) != null){
//5.对读取到的文本进行切割,获取行中的序号和文本内容
String[] arr = line.split("\\.");
//6.把切割好的序号和文本内容存储到HashMap集合中(key序号是有序的,会自动排序1,2,3...)
map.put(arr[0],arr[1]);
}
//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();
}
}
运行结果:
int.txt中内容为:
6.岑夫子,丹丘生,将进酒,杯莫停。
9.古来圣贤皆寂寞,惟有饮者留其名。
1.君不见,黄河之水天上来,奔流到海不复回。
5.烹羊宰牛且为乐,会须一饮三百杯。
3.人生得意须尽欢,莫使金樽空对月。
8.钟鼓馔玉不足贵,但愿长醉不复醒。
2.君不见,高堂明镜悲白发,朝如青丝暮成雪。
7.与君歌一曲,请君为我倾耳听。
4.天生我材必有用,千金散尽还复来。
out.txt中内容为:
1.君不见,黄河之水天上来,奔流到海不复回。
2.君不见,高堂明镜悲白发,朝如青丝暮成雪。
3.人生得意须尽欢,莫使金樽空对月。
4.天生我材必有用,千金散尽还复来。
5.烹羊宰牛且为乐,会须一饮三百杯。
7.与君歌一曲,请君为我倾耳听。
8.钟鼓馔玉不足贵,但愿长醉不复醒。
6.岑夫子,丹丘生,将进酒,杯莫停。
9.古来圣贤皆寂寞,惟有饮者留其名。