java 遍歷指定目錄下的文件夾并查找包含指定關(guān)鍵字的文件

引自:https://www.cnblogs.com/longronglang/p/7457989.html

import java.io.File;
import java.io.FileFilter;
import java.io.FilenameFilter;
import java.util.ArrayList;
import java.util.List;

public class Demo {
static int countFiles = 0;// 聲明統(tǒng)計(jì)文件個(gè)數(shù)的變量
static int countFolders = 0;// 聲明統(tǒng)計(jì)文件夾的變量

public static File[] searchFile(File folder, final String keyWord) {// 遞歸查找包含關(guān)鍵字的文件

    File[] subFolders = folder.listFiles(new FileFilter() {// 運(yùn)用內(nèi)部匿名類獲得文件
        @Override
        public boolean accept(File pathname) {// 實(shí)現(xiàn)FileFilter類的accept方法
            if (pathname.isFile())// 如果是文件
                countFiles++;
            else
                // 如果是目錄
                countFolders++;
            if (pathname.isDirectory()
                    || (pathname.isFile() && pathname.getName().toLowerCase().contains(keyWord.toLowerCase())))// 目錄或文件包含關(guān)鍵字
                return true;
            return false;
        }
    });

    List<File> result = new ArrayList<File>();// 聲明一個(gè)集合
    for (int i = 0; i < subFolders.length; i++) {// 循環(huán)顯示文件夾或文件
        if (subFolders[i].isFile()) {// 如果是文件則將文件添加到結(jié)果列表中
            result.add(subFolders[i]);
        } else {// 如果是文件夾,則遞歸調(diào)用本方法,然后把所有的文件加到結(jié)果列表中
            File[] foldResult = searchFile(subFolders[i], keyWord);
            for (int j = 0; j < foldResult.length; j++) {// 循環(huán)顯示文件
                result.add(foldResult[j]);// 文件保存到集合中
            }
        }
    }

    File files[] = new File[result.size()];// 聲明文件數(shù)組,長(zhǎng)度為集合的長(zhǎng)度
    result.toArray(files);// 集合數(shù)組化
    return files;
}

public static void main(String[] args) {// java程序的主入口處
    File folder = new File("/Users/lijunchen/programe/workspace");// 默認(rèn)目錄
    String keyword = "BusinessException";
    if (!folder.exists()) {// 如果文件夾不存在
        System.out.println("目錄不存在:" + folder.getAbsolutePath());
        return;
    }
    File[] result = searchFile(folder, keyword);// 調(diào)用方法獲得文件數(shù)組
    System.out.println("在 " + folder + " 以及所有子文件時(shí)查找對(duì)象" + keyword);
    System.out.println("查找了" + countFiles + " 個(gè)文件," + countFolders + " 個(gè)文件夾,共找到 " + result.length + " 個(gè)符合條件的文件:");
    for (int i = 0; i < result.length; i++) {// 循環(huán)顯示文件
        File file = result[i];
        System.out.println(file.getAbsolutePath() + " ");// 顯示文件絕對(duì)路徑
    }
}

}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容