java使用FileVisitor遍歷文件和目錄
在早期的Java版本中,如果需要對指定目錄下的文件進行遍歷,則需要用遞歸的方法來實現(xiàn),這種方法有點復雜,而且靈活性也不高。而使用Java7中Files工具類中的walkFileTree()方法可以很容易的實現(xiàn)對目錄下的所有文件進行遍歷。這個方法需要一個Path和一個FileVisitor參數(shù)。其中Path是要遍歷的路徑,而FileVisitor則可以看成的一個文件訪問器,它主要提供的四個方法,這在程序中可以看到。而FileVisitor四個方法返回的都是FileVisitResult對象,它是一個枚舉類,代表的是返回之后的一些后續(xù)的操作。
FileVisitResult主要包含四個常見的操作。
1、FileVisitResult.CONTINUE 繼續(xù)遍歷
2、FileVisitResult.TERMINATE 中止訪問
3、FileVisitResult.SKIP_SIBLINGS 不訪問同級的文件或目錄
4、FileVisitResult.SKIP_SUBTREE 不訪問子目錄
通過創(chuàng)建SimpleFileVisitor對象來對文件進行遍歷即可,它是FileVisitor的實現(xiàn)類,這樣可以有選擇的重寫指定的方法
下面的程序是使用FileVisitor對目錄進行遍歷,該程序還簡單實現(xiàn)了在指定的目錄下查找文件。
package com.sdjz.test1;
import java.io.IOException;
import java.nio.file.FileVisitResult;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.SimpleFileVisitor;
import java.nio.file.attribute.BasicFileAttributes;
import java.util.List;
public class FileVisitorTest {
public static void main(String[] args) throws IOException {
// 使用FileVisitor對目錄進行遍歷
Files.walkFileTree(Paths.get("d:", "workspace"), new SimpleFileVisitor<Path>() {
// 在訪問子目錄前觸發(fā)該方法
@Override
public FileVisitResult preVisitDirectory(Path dir, BasicFileAttributes attrs) throws IOException {
System.out.println("正在訪問" + dir + "目錄");
return FileVisitResult.CONTINUE;
}
// 在訪問文件時觸發(fā)該方法
@Override
public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException {
System.out.println("正在訪問" + file + "文件");
if (file.endsWith("FilesTest.java")) {
System.out.println("------已找到FilesTest.java,文件內(nèi)容-----");
List<String> list = Files.readAllLines(file);
// 打印出文件的內(nèi)容
System.out.println(list);
return FileVisitResult.TERMINATE;
}
return FileVisitResult.CONTINUE;
}
// 在訪問失敗時觸發(fā)該方法
@Override
public FileVisitResult visitFileFailed(Path file, IOException exc) throws IOException {
// 寫一些具體的業(yè)務邏輯
return super.visitFileFailed(file, exc);
}
// 在訪問目錄之后觸發(fā)該方法
@Override
public FileVisitResult postVisitDirectory(Path dir, IOException exc) throws IOException {
// 寫一些具體的業(yè)務邏輯
return super.postVisitDirectory(dir, exc);
}
});
}
}
下面的程序運行的效果

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
解決IDEA中Maven依賴包導入失敗報紅問題(總結(jié)最有效8種解決方案)
這篇文章主要介紹了解決IDEA中Maven依賴包導入失敗報紅問題,本文通過圖文詳解給大家總結(jié)了最有效的8種解決方法,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07
雪花算法(snowflak)生成有序不重復ID的Java實現(xiàn)代碼
雪花算法是一種分布式系統(tǒng)中生成唯一ID的方法,由41位時間戳、10位機器碼和12位序列號組成,具有唯一性、有序性和高效率等優(yōu)點,這篇文章主要介紹了雪花算法(snowflak)生成有序不重復ID的Java實現(xiàn)的相關(guān)資料,需要的朋友可以參考下2024-11-11
springboot springmvc拋出全局異常的解決方法
這篇文章主要為大家詳細介紹了springboot springmvc拋出全局異常的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06

