有时需要递归遍历一个文件树,比如查找一个文件夹内符合条件的文件,查找某一天创建的文件……。jdk7 nio包提供一个新的接口 FileVisitor。它提供了遍历文件树的各种操作。
preVisitDirectory - 一个路径被访问时调用
PostVisitDirectory - 一个路径的所有节点被访问后调用。如果有错误发生,exception会传递给这个方法
visitFile - 文件被访问时被调用。该文件的文件属性被传递给这个方法
visitFileFailed - 当文件不能被访问时,此方法被调用。Exception被传递给这个方法。
如果你比较懒,不想实现所有方法。你可以选择继承 SimpleFileVisitor。它帮你实现了上述方法,你只需Override 你感兴趣的方法。
下面给个例子,简单地遍历一个文件夹,打印出所有信息
Java代码
- 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;
- /**
- * @author kencs@foxmail.com
- */
- public class FileVisitorTest extends SimpleFileVisitor
{ - private void find(Path path){
- System.out.printf("访问-%s:%s%n",(Files.isDirectory(path)?"目录":"文件"),path.getFileName());
- }
- @Override
- public FileVisitResult visitFile(Path file,BasicFileAttributes attrs){
- find(file);
- return FileVisitResult.CONTINUE;
- }
- @Override
- public FileVisitResult preVisitDirectory(Path dir,BasicFileAttributes attrs){
- find(dir);
- return FileVisitResult.CONTINUE;
- }
- @Override
- public FileVisitResult visitFileFailed(Path file,IOException e){
- System.out.println(e);
- return FileVisitResult.CONTINUE;
- }
- public static void main(String[] args) throws IOException{
- if(args.length!=1){
- System.out.println("请输入一个文件路径作为参数");
- System.exit(-1);
- }
- Files.walkFileTree(Paths.get( args[0]), new FileVisitorTest());
- }
- }
随便选择一个路径作为参数
java FileVisitorTest "C:\\Program Files\\Java\\jre7\\bin"
运行结果代码
- 访问-目录:bin
- 访问-文件:awt.dll
- 访问-文件:axbridge.dll
- 访问-目录:client
- 访问-文件:classes.jsa
- 访问-文件:jvm.dll
- 访问-文件:Xusage.txt
- 访问-文件:dcpr.dll
- 访问-文件:deploy.dll
- 访问-文件:deployJava1.dll
- 访问-文件:dt_shmem.dll
- 访问-文件:dt_socket.dll
- ......
注意 FileVisitResult有四种
CONTINUE –继续
TERMINATE –终止,这次遍历结束了
SKIP_SUBTREE –子树(当前路径的子目录)不再遍历了
SKIP_SIBLINGS –兄弟节点(同级别目录)不再访问了。
可以通过这些返回值来控制遍历文件树的流程
【编辑推荐】