java查找文件夾下最新生成的文件的方法
java 操作文件是非常重要的,主要是操作File類,這里一起探討下,java怎么查找文件夾下最新生成的文件,希望對大家有幫助,謝謝
第一步
在本地電腦上找一個目錄,包含幾個文件,修改的時間有差別:

第二步
打開eclipse創(chuàng)建一個測試類,主要操作File類:

第三步
編寫一個遞歸方法,可以變量這個目錄下所有的文件,并輸出文件的路徑,和最后修改時間

第四步
定義main函數(shù),調(diào)用遞歸函數(shù),輸出所有文件的修改時間:

第五步
修改print方法,記錄出最近修改的文件路徑和修改的時間:


java如何查找指定目錄下的最新文件
package net.xsoftlab.baike;
import java.io.File;
import java.io.FileFilter;
import java.util.ArrayList;
import java.util.List;
//查找目錄下指定文件名的文件
public class TextSearchFile {
static int countFiles = 0;// 聲明統(tǒng)計文件個數(shù)的變量
static int countFolders = 0;// 聲明統(tǒng)計文件夾的變量
public static File[] searchFile(File folder, final String keyWord) {// 遞歸查找包含關鍵字的文件
File[] subFolders = folder.listFiles(new FileFilter() {// 運用內(nèi)部匿名類獲得文件
@Override
public boolean accept(File pathname) {// 實現(xiàn)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++) {// 循環(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ù)組,長度為集合的長度
result.toArray(files);// 集合數(shù)組化
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);// 調(diào)用方法獲得文件數(shù)組
System.out.println("在 " + folder + " 以及所有子文件時查找對象" + keyword);
System.out.println("查找了" + countFiles + " 個文件," + countFolders + " 個文件夾,共找到 " + result.length + " 個符合條件的文件:");
for (int i = 0; i < result.length; i++) {// 循環(huán)顯示文件
File file = result[i];
System.out.println(file.getAbsolutePath() + " ");// 顯示文件絕對路徑
}
}
}
相關文章
Netty進階之EventExecutorGroup源碼詳解
這篇文章主要介紹了Netty進階之EventExecutorGroup源碼詳解,EventExecutorGroup繼承了JDK的ScheduledExecutroService,那么它就擁有了執(zhí)行定時任務,執(zhí)行提交的普通任務,需要的朋友可以參考下2023-11-11
Spring利用@Validated注解實現(xiàn)參數(shù)校驗詳解
這篇文章主要為大家詳細介紹了在?Spring?項目中使用?@Validated?進行參數(shù)校驗的方法和常見應用場景,感興趣的小伙伴可以跟隨小編一起學習一下2023-05-05
Spring?Boot存在路徑遍歷漏洞CVE-2021-22118的問題解析
CVE-2021-22118?是一個在?Spring?Boot?中發(fā)現(xiàn)的漏洞,該漏洞關系到?Spring?Boot?的開發(fā)者工具(Devtools)中的遠程更新(Remote?Update)功能,這篇文章主要介紹了Spring?Boot存在路徑遍歷漏洞CVE-2021-22118,需要的朋友可以參考下2023-09-09
詳解Mybatis 傳遞參數(shù)類型為List的取值問題
這篇文章主要介紹了詳解Mybatis 傳遞參數(shù)類型為List的取值問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-10-10
java 中用split分割字符串,最后的空格等不被拆分的方法
下面小編就為大家?guī)硪黄猨ava 中用split分割字符串,最后的空格等不被拆分的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02
Java橋梁設計模式優(yōu)雅地將抽象與實現(xiàn)分離
Java橋接設計模式通過將抽象和實現(xiàn)分離,使得它們可以獨立地變化,從而實現(xiàn)更靈活的代碼結(jié)構(gòu)。它是一種優(yōu)雅的設計模式,適用于需要處理多個變化因素的復雜應用程序2023-04-04

