溫馨提示×

溫馨提示×

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

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

Java遞歸遍歷文件目錄代碼實例

發(fā)布時間:2020-10-22 03:20:44 來源:腳本之家 閱讀:139 作者:PYD-inazuma 欄目:編程語言

這篇文章主要介紹了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對象,得到的結果是沒有排序之前的數據。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI