溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java怎么遞歸遍歷文件目錄

發(fā)布時間:2021-09-14 23:40:10 來源:億速云 閱讀:199 作者:chen 欄目:編程語言

這篇文章主要介紹“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>

向AI問一下細(xì)節(jié)

免責(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)容。

AI