1. 程式人生 > >文件的查找

文件的查找

數組 files lte result arr ldr 絕對路徑 實現 文件夾

package work.code.text; import java.io.File; import java.io.FileFilter; import java.util.ArrayList; import java.util.List; public class TestSearchFile { static int countFiles = 0;// 聲明統計文件個數的變量 static int countFolders = 0;// 聲明統計文件夾的變量 public static File[] searchFile(File folder, final String keyWord) {// 遞歸查找包含關鍵字的文件 File[] subFolders = folder.listFiles(new FileFilter() {// 運用內部匿名類獲得文件 @Override public boolean accept(File pathname) {// 實現FileFilter類的accept方法 if (pathname.isFile())// 如果是文件 countFiles++; else // 如果是目錄 countFolders++; if (pathname.isDirectory() || (pathname.isFile() && pathname.getName().toLowerCase().contains(keyWord.toLowerCase())))// 目錄或文件包含關鍵字 return true; return false; } }); List<File> result = new ArrayList<File>();// 聲明一個集合 for (int i = 0; i < subFolders.length; i++) {// 循環顯示文件夾或文件 if (subFolders[i].isFile()) {// 如果是文件則將文件添加到結果列表中 result.add(subFolders[i]); } else {// 如果是文件夾,則遞歸調用本方法,然後把所有的文件加到結果列表中 File[] foldResult = searchFile(subFolders[i], keyWord); for (int j = 0; j < foldResult.length; j++) {// 循環顯示文件 result.add(foldResult[j]);// 文件保存到集合中 } } } File files[] = new File[result.size()];// 聲明文件數組,長度為集合的長度 result.toArray(files);// 集合數組化 return files; } public static void main(String[] args) {// java程序的主入口處 File folder = new File("E:/baidu");// 默認目錄 String keyword = "1231"; if (!folder.exists()) {// 如果文件夾不存在 System.out.println("目錄不存在:" + folder.getAbsolutePath()); return; } File[] result = searchFile(folder, keyword);// 調用方法獲得文件數組 System.out.println("在 " + folder + " 以及所有子文件時查找對象" + keyword); System.out.println("查找了" + countFiles + " 個文件," + countFolders + " 個文件夾,共找到 " + result.length + " 個符合條件的文件:"); for (int i = 0; i < result.length; i++) {// 循環顯示文件 File file = result[i]; System.out.println(file.getAbsolutePath() + " ");// 顯示文件絕對路徑 } } }


文件的查找