這篇文章主要介紹“Java怎么遞歸遍歷文件目錄”,在日常操作中,相信很多人在Java怎么遞歸遍歷文件目錄問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Java怎么遞歸遍歷文件目錄”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
目前創(chuàng)新互聯(lián)建站已為1000多家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)站空間、網(wǎng)站托管、企業(yè)網(wǎng)站設(shè)計、余慶網(wǎng)站維護(hù)等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。代碼如下
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)建哈希表 Maphm = 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 map) { //重寫List降序排序 List > infoIds = new ArrayList >(map.entrySet()); Collections.sort(infoIds, new Comparator >() { public int compare(Map.Entry o1, Map.Entry o2) { return (o2.getValue() - o1.getValue()); } }); //輸出 for (int i = 0; i < infoIds.size(); i++) { Entry id = infoIds.get(i); System.out.println(id.getKey()+":"+id.getValue()); } }}
此次任務(wù)只需要編寫一個能夠?qū)崿F(xiàn)遞歸遍歷文件目錄的方法即可,重點(diǎn)還是統(tǒng)計單詞個數(shù)和排序輸出,這次統(tǒng)計與排序全部都由HashMap完成,統(tǒng)計方法是在編入單詞之前先使用containsKey()抓取已存在的鍵信息,若單詞存在其值+1,否則新構(gòu)建鍵,以值為1的形式存入該單詞。
排序則是重寫List方法實(shí)現(xiàn),輸出時要注意遍歷重寫后的List對象,如果遍歷的是之前創(chuàng)建的HashMap對象,得到的結(jié)果是沒有排序之前的數(shù)據(jù)。
到此,關(guān)于“Java怎么遞歸遍歷文件目錄”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!