您好,登錄后才能下訂單哦!
這篇文章主要介紹“Java怎么遞歸遍歷文件目錄”,在日常操作中,相信很多人在Java怎么遞歸遍歷文件目錄問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Java怎么遞歸遍歷文件目錄”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
代碼如下
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(); //調(diào)用遍歷方法 K.Run("E:\\article"); } //遞歸遍歷文件 public void Run(String AllFile) { File tfile = new File(AllFile); //構(gòu)建文件數(shù)組 File[] files = tfile.listFiles(); for(int i = 0; i < files.length; i++) { //判定該文件是否為目錄 if(files[i].isDirectory()) { //是,遞歸調(diào)用函數(shù) Run(files[i].getAbsolutePath()); }else { //不是,讀取文件輸出單詞個數(shù) System.out.println("**********"+files[i].getAbsolutePath()+"**********"); ReadFile(files[i].getAbsolutePath()); } } } //統(tǒng)計單詞個數(shù),排序,輸出 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){ //利用正則表達(dá)式分割出單詞 String[]strs = s.split("[^a-zA-Z0-9]"); //向哈希表存入單詞,統(tǒng)計個數(shù) 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); } } } //調(diào)用排序方法 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()); } }}
此次任務(wù)只需要編寫一個能夠?qū)崿F(xiàn)遞歸遍歷文件目錄的方法即可,重點還是統(tǒng)計單詞個數(shù)和排序輸出,這次統(tǒng)計與排序全部都由HashMap完成,統(tǒng)計方法是在編入單詞之前先使用containsKey()抓取已存在的鍵信息,若單詞存在其值+1,否則新構(gòu)建鍵,以值為1的形式存入該單詞。
排序則是重寫List方法實現(xiàn),輸出時要注意遍歷重寫后的List對象,如果遍歷的是之前創(chuàng)建的HashMap對象,得到的結(jié)果是沒有排序之前的數(shù)據(jù)。
到此,關(guān)于“Java怎么遞歸遍歷文件目錄”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。