如何在Java中循环访问目录中的文件及其子目录?
2022-08-31 06:26:52
我需要获取目录中所有文件的列表,包括所有子目录中的文件。使用 Java 完成目录迭代的标准方法是什么?
我需要获取目录中所有文件的列表,包括所有子目录中的文件。使用 Java 完成目录迭代的标准方法是什么?
可以使用 File#isDirectory()
来测试给定的文件(路径)是否为目录。如果是 ,则只需使用其 File#listFiles()
结果再次调用相同的方法。这称为递归。true
下面是一个基本的启动示例:
package com.stackoverflow.q3154488;
import java.io.File;
public class Demo {
public static void main(String... args) {
File dir = new File("/path/to/dir");
showFiles(dir.listFiles());
}
public static void showFiles(File[] files) {
for (File file : files) {
if (file.isDirectory()) {
System.out.println("Directory: " + file.getAbsolutePath());
showFiles(file.listFiles()); // Calls same method again.
} else {
System.out.println("File: " + file.getAbsolutePath());
}
}
}
}
请注意,当树的深度超过 JVM 的堆栈所能容纳的深度时,这对 StackOverflowError
很敏感。如果你已经在使用Java 8或更高版本,那么你最好使用Files#walk()
代替它,它利用尾递归:
package com.stackoverflow.q3154488;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
public class DemoWithJava8 {
public static void main(String... args) throws Exception {
Path dir = Paths.get("/path/to/dir");
Files.walk(dir).forEach(path -> showFile(path.toFile()));
}
public static void showFile(File file) {
if (file.isDirectory()) {
System.out.println("Directory: " + file.getAbsolutePath());
} else {
System.out.println("File: " + file.getAbsolutePath());
}
}
}
如果您使用的是Java 1.7,则可以使用java.nio.file.Files.walkFileTree(...)。
。
例如:
public class WalkFileTreeExample {
public static void main(String[] args) {
Path p = Paths.get("/usr");
FileVisitor<Path> fv = new SimpleFileVisitor<Path>() {
@Override
public FileVisitResult visitFile(Path file, BasicFileAttributes attrs)
throws IOException {
System.out.println(file);
return FileVisitResult.CONTINUE;
}
};
try {
Files.walkFileTree(p, fv);
} catch (IOException e) {
e.printStackTrace();
}
}
}
如果您使用的是 Java 8,则可以将流接口与 java.nio.file.Files.walk(...) 一起使用
:
public class WalkFileTreeExample {
public static void main(String[] args) {
try (Stream<Path> paths = Files.walk(Paths.get("/usr"))) {
paths.forEach(System.out::println);
} catch (IOException e) {
e.printStackTrace();
}
}
}