读入 排序前出师表.txt 文本信息,进行排序输出为 排序后出师表.txt 文件
排序前出师表.txt
3.侍中、侍郎郭攸之、费祎、董允等,此皆良实,志虑忠纯,是以先帝简拔以遗陛下。愚以为宫中之事,事无大小,悉以咨之,然后施行,必得裨补阙漏,有所广益。
8.愿陛下托臣以讨贼兴复之效,不效,则治臣之罪,以告先帝之灵。若无兴德之言,则责攸之、祎、允等之慢,以彰其咎;陛下亦宜自谋,以咨承善道,蔡纳雅言,深追先帝遗诏,臣不胜受恩感激。
4.将军向宠,性行淑均,晓畅军事,试用之于昔日,先帝称之日能,是以众议举宠为督。愚以为营中之事,悉以咨之,必能使行阵和睦,优劣得所。
2.宫中府中,俱为一体,陟罚臧否,不宜异同。若有作奸犯科及为忠善者,宜付有司论其刑赏,以昭陛下平明之理,不言偏私,使内外异法也。
1.先帝创业未半而中道崩殂,今天下三分,益州疲弊,此诚危急存亡之秋也。然侍卫之臣不懈于内,忠志之士忘身于外者,盖追先帝之殊遇,欲报之于陛下也。诚宜开张圣听,以光先帝遗德,恢弘志士之气,不宜妄自菲薄,引嗡失义,以塞忠谏之路也。
9.今当远离,临表涕零,不知所言。
6.臣本布衣,躬耕于南阳,苟全性命于乱世,不求闻达于诸侯。先帝不以臣卑鄙,猥自枉屈,三顾臣于草庐之中,咨臣以当世之事,由是感激,遂许先帝以驱驰。后值倾覆,受任于败军之际,奉命于危难之间,尔来二十有一年矣。
7.先帝知臣谨慎,故临崩寄臣以大事也。受命以来,夙夜忧叹,恐付托不效,以伤先帝之明,故五月渡泸,深入不毛。今南方已定,兵甲已足,当奖率三军,北定中原,庶竭驽钝,攘除奸凶,兴复汉室,还于旧都。此臣所以报先帝而忠陛下之职分也。至于斟酌损益,进尽忠言,则攸之、祎、允之任也。
5.亲贤臣,远小人,此先汉所以兴隆也;亲小人,远贤臣,此后汉所以倾颓也。先帝在时,每与臣论此事,未尝不叹息痛恨于桓、灵也。侍中、尚书、长史、参军,此悉贞良死节之臣,愿陛下亲之信之,则汉室之隆,可计日而待也。
排序后出师表.txt
1.先帝创业未半而中道崩殂,今天下三分,益州疲弊,此诚危急存亡之秋也。然侍卫之臣不懈于内,忠志之士忘身于外者,盖追先帝之殊遇,欲报之于陛下也。诚宜开张圣听,以光先帝遗德,恢弘志士之气,不宜妄自菲薄,引嗡失义,以塞忠谏之路也。
2.宫中府中,俱为一体,陟罚臧否,不宜异同。若有作奸犯科及为忠善者,宜付有司论其刑赏,以昭陛下平明之理,不言偏私,使内外异法也。
3.侍中、侍郎郭攸之、费祎、董允等,此皆良实,志虑忠纯,是以先帝简拔以遗陛下。愚以为宫中之事,事无大小,悉以咨之,然后施行,必得裨补阙漏,有所广益。
4.将军向宠,性行淑均,晓畅军事,试用之于昔日,先帝称之日能,是以众议举宠为督。愚以为营中之事,悉以咨之,必能使行阵和睦,优劣得所。
5.亲贤臣,远小人,此先汉所以兴隆也;亲小人,远贤臣,此后汉所以倾颓也。先帝在时,每与臣论此事,未尝不叹息痛恨于桓、灵也。侍中、尚书、长史、参军,此悉贞良死节之臣,愿陛下亲之信之,则汉室之隆,可计日而待也。
6.臣本布衣,躬耕于南阳,苟全性命于乱世,不求闻达于诸侯。先帝不以臣卑鄙,猥自枉屈,三顾臣于草庐之中,咨臣以当世之事,由是感激,遂许先帝以驱驰。后值倾覆,受任于败军之际,奉命于危难之间,尔来二十有一年矣。
7.先帝知臣谨慎,故临崩寄臣以大事也。受命以来,夙夜忧叹,恐付托不效,以伤先帝之明,故五月渡泸,深入不毛。今南方已定,兵甲已足,当奖率三军,北定中原,庶竭驽钝,攘除奸凶,兴复汉室,还于旧都。此臣所以报先帝而忠陛下之职分也。至于斟酌损益,进尽忠言,则攸之、祎、允之任也。
8.愿陛下托臣以讨贼兴复之效,不效,则治臣之罪,以告先帝之灵。若无兴德之言,则责攸之、祎、允等之慢,以彰其咎;陛下亦宜自谋,以咨承善道,蔡纳雅言,深追先帝遗诏,臣不胜受恩感激。
9.今当远离,临表涕零,不知所言。
小提示:如果排序后出现序号正确但是后面乱码的情况,那是因为字符集冲突的原因,一般 windows 的系统默认的字符集都是 GBK ,但 IDEA 或 Eclipse 有时可能不是使用的 GBK ,极可能是其他的字符集,比如: UTF-8 ,因此这种情况是正常的,如果做到这一步了,那这一部分的小练习也算是完成了的。
代码:
/*
*@author MingxuDeng
*@version 20202020年10月30日
字符缓冲输入流&Map 集合的简单综合应用:
文本排序
读入 排序前出师表.txt 文本信息,进行排序输出为 排序后出师表.txt 文件
即:对文本的内容进行排序
按照(1,2,3,...)顺序进行排序
分析:
1.创建一个 HashMap 集合对象:key 可以存储每行文本的序号(1,2,3,...);value:存储每行的文本;HashMap特性:对key进行排序后存储。
2.读:创建字符缓冲输入流对象,构造方法中绑定字符输入流;
3.写:创建字符缓冲输出流对象,构造方法中绑定字符输出流;
4.使用字符缓冲输入流中的方法 readLine ,逐行读取文本;
5.对读取到的文本进行切割,获取行中的序号和文本内容;
6.把切割好的序号和文本的内容存储到 HashMap 集合中(Map 集合中的key序号是有序的,会自动排序 1,2,3,4,...);
7.遍历 HashMap 集合,获取每一个键值对;
8.把每一个键值对,拼接为一个文本行,(注意换行符:这里可以使用方法newLine);
9.把拼接好的文本,使用字符缓冲输出流中的方法 write,写入到文件(排序后出师表.txt)中;
10.释放资源;
*/
package 缓冲流;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.HashMap;
public class Demo_sort {
public static void main(String[] args) throws IOException {
//1.创建一个 HashMap 集合对象:key 可以存储每行文本的序号(1,2,3,...);value:存储每行的文本;
HashMap<String,String> map = new HashMap<>();
//2.读:创建字符缓冲输入流对象,构造方法中绑定字符输入流; 这里的路径可根据文本在电脑实际对应路径来进行配置
BufferedReader br = new BufferedReader(new FileReader("C:\\Users\\Administrator\\Desktop\\排序前出师表.txt"));
//3.写:创建字符缓冲输出流对象,构造方法中绑定字符输出流; 这里的路径可根据文本在电脑实际对应路径来进行配置
BufferedWriter bw = new BufferedWriter(new FileWriter("C:\\Users\\Administrator\\Desktop\\排序后的出师表.txt"));
//4.使用字符缓冲输入流中的方法 readLine ,逐行读取文本;
String line;
while((line=br.readLine())!=null) {
//5.对读取到的文本进行切割,获取行中的序号和文本内容;
String[] arr=new String[2];
arr = line.split("\\.");// 以"."为界进行切割分离
//6.把切割好的序号和文本的内容存储到 HashMap 集合中(Map 集合中的key序号是有序的,会自动排序 1,2,3,4,...);
//方法一:
for (int i = 0; i < arr.length-1; i++) {
map.put(arr[i], arr[i+1]);
}
//6.把切割好的序号和文本的内容存储到 HashMap 集合中(Map 集合中的key序号是有序的,会自动排序 1,2,3,4,...);
//方法二:
//map.put(arr[0], arr[1]);
}
//7.遍历 HashMap 集合,获取每一个键值对;
for (String key : map.keySet()) {
String value = map.get(key);
//8.把每一个键值对,拼接为一个文本行,(注意换行符:这里可以使用方法newLine);
line = key+"."+value;
//9.把拼接好的文本,使用字符缓冲输出流中的方法 write,写入到文件(排序后出师表.txt)中;
bw.write(line);
bw.newLine();//写换行
}
//10.释放资源;
bw.close();
br.close();
}
}