您好,登錄后才能下訂單哦!
這篇文章主要介紹了Java遞歸遍歷文件目錄代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
在讀取文件降序輸出單詞及其個數的基礎上,將txt文件存入文件夾中,開始遞歸遍歷文件目錄,之后輸出txt文件中的單詞及其個數,仍然是降序排列。
代碼如下
import java.io.BufferedReader; import java.io.File; import java.io.FileReader; import java.util.Map; import java.util.Map.Entry; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.HashMap; import java.util.List; public class Traverse4 { public static void main(String[] args) { Traverse4 K = new Traverse4(); //調用遍歷方法 K.Run("E:\\article"); } //遞歸遍歷文件 public void Run(String AllFile) { File tfile = new File(AllFile); //構建文件數組 File[] files = tfile.listFiles(); for(int i = 0; i < files.length; i++) { //判定該文件是否為目錄 if(files[i].isDirectory()) { //是,遞歸調用函數 Run(files[i].getAbsolutePath()); }else { //不是,讀取文件輸出單詞個數 System.out.println("**********"+files[i].getAbsolutePath()+"**********"); ReadFile(files[i].getAbsolutePath()); } } } //統(tǒng)計單詞個數,排序,輸出 public void ReadFile(String fname) { File file=new File(fname); try { FileReader fr = new FileReader(file); BufferedReader bufr = new BufferedReader(fr); String s = null; //創(chuàng)建哈希表 Map<String,Integer> hm = new HashMap<>(); while((s=bufr.readLine())!=null){ //利用正則表達式分割出單詞 String[]strs = s.split("[^a-zA-Z0-9]"); //向哈希表存入單詞,統(tǒng)計個數 for(int i = 0; i < strs.length; i++){ strs[i].toLowerCase(); if(!hm.containsKey(strs[i])){ hm.put(strs[i], 1); }else{ Integer counts = hm.get(strs[i]); hm.put(strs[i], counts+1); } } } //調用排序方法 sort(hm); bufr.close(); fr.close(); }catch(Exception e){ e.printStackTrace(); } } public void sort(Map<String,Integer>map) { //重寫List降序排序 List<Map.Entry<String, Integer>> infoIds = new ArrayList<Map.Entry<String, Integer>>(map.entrySet()); Collections.sort(infoIds, new Comparator<Map.Entry<String, Integer>>() { public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) { return (o2.getValue() - o1.getValue()); } }); //輸出 for (int i = 0; i < infoIds.size(); i++) { Entry<String, Integer> id = infoIds.get(i); System.out.println(id.getKey()+":"+id.getValue()); } } }
此次任務只需要編寫一個能夠實現遞歸遍歷文件目錄的方法即可,重點還是統(tǒng)計單詞個數和排序輸出,這次統(tǒng)計與排序全部都由HashMap完成,統(tǒng)計方法是在編入單詞之前先使用containsKey()抓取已存在的鍵信息,若單詞存在其值+1,否則新構建鍵,以值為1的形式存入該單詞。
排序則是重寫List方法實現,輸出時要注意遍歷重寫后的List對象,如果遍歷的是之前創(chuàng)建的HashMap對象,得到的結果是沒有排序之前的數據。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。