练习:文本排序
練習(xí):
? ? ? ? 對(duì)文本的內(nèi)容進(jìn)行排序
? ? ? ? 按照(1,2,3....)順序排序
? ? 分析:
? ? ? ? 1.創(chuàng)建一個(gè)HashMap集合對(duì)象,可以:存儲(chǔ)每行文本的序號(hào)(1,2,3,..);value:存儲(chǔ)每行的文本
? ? ? ? 2.創(chuàng)建字符緩沖輸入流對(duì)象,構(gòu)造方法中綁定字符輸入流
? ? ? ? 3.創(chuàng)建字符緩沖輸出流對(duì)象,構(gòu)造方法中綁定字符輸出流
? ? ? ? 4.使用字符緩沖輸入流中的方法readline,逐行讀取文本
? ? ? ? 5.對(duì)讀取到的文本進(jìn)行切割,獲取行中的序號(hào)和文本內(nèi)容
? ? ? ? 6.把切割好的序號(hào)和文本的內(nèi)容存儲(chǔ)到HashMap集合中(key序號(hào)是有序的,會(huì)自動(dòng)排序1,2,3,4..)
? ? ? ? 7.遍歷HashMap集合,獲取每一個(gè)鍵值對(duì)
? ? ? ? 8.把每一個(gè)鍵值對(duì),拼接為一個(gè)文本行
? ? ? ? 9.把拼接好的文本,使用字符緩沖輸出流中的方法write,寫入到文件中
? ? ? ? 10.釋放資源
package com.itheima.demo01.BufferedStream;import java.io.*; import java.util.HashMap;public class Demo05Test {public static void main(String[] args) throws IOException {//1.創(chuàng)建一個(gè)HashMap集合對(duì)象,可以:存儲(chǔ)每行文本的序號(hào)(1,2,3,..);value:存儲(chǔ)每行的文本HashMap<String,String> map = new HashMap<>();//2.創(chuàng)建字符緩沖輸入流對(duì)象,構(gòu)造方法中綁定字符輸入流BufferedReader br = new BufferedReader(new FileReader("10_IO\\in.txt"));//3.創(chuàng)建字符緩沖輸出流對(duì)象,構(gòu)造方法中綁定字符輸出流BufferedWriter bw = new BufferedWriter(new FileWriter("10_IO\\out.txt"));//4.使用字符緩沖輸入流中的方法readline,逐行讀取文本String line;while((line = br.readLine())!=null){//5.對(duì)讀取到的文本進(jìn)行切割,獲取行中的序號(hào)和文本內(nèi)容String[] arr = line.split("\\.");//6.把切割好的序號(hào)和文本的內(nèi)容存儲(chǔ)到HashMap集合中(key序號(hào)是有序的,會(huì)自動(dòng)排序1,2,3,4..)map.put(arr[0],arr[1]);}//7.遍歷HashMap集合,獲取每一個(gè)鍵值對(duì)for(String key : map.keySet()){String value = map.get(key);//8.把每一個(gè)鍵值對(duì),拼接為一個(gè)文本行l(wèi)ine = key + "." + value;//9.把拼接好的文本,使用字符緩沖輸出流中的方法write,寫入到文件中bw.write(line);bw.newLine();//寫換行}//10.釋放資源bw.close();br.close();} }
?
總結(jié)
- 上一篇: 属性集
- 下一篇: do……while 循环