使用 walkfiletree 遍历文件夹
在Java中,可以使用`Files.walkFileTree()`方法来遍历文件夹及其子文件夹中的所有文件和目录。`walkFileTree()`方法是Java 7中引入的`FileVisitor`接口的一个实现。
下面是一个示例代码,演示如何使用`Files.walkFileTree()`方法来遍历文件夹:
```java
import java.io.IOException;
import java.nio.file.FileVisitResult;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.SimpleFileVisitor;
import java.nio.file.attribute.BasicFileAttributes;
public class FileVisitorExample {
public static void main(String[] args) {
Path folderPath = Path.of("/path/to/folder"); // 指定要遍历的文件夹路径
try {
Files.walkFileTree(folderPath, new SimpleFileVisitor<>() {
@Override
public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException {
System.out.println("File: " + file);
return FileVisitResult.CONTINUE;
}
@Override
public FileVisitResult preVisitDirectory(Path dir, BasicFileAttributes attrs) throws IOException {
System.out.println("Directory: " + dir);
return FileVisitResult.CONTINUE;
}
@Override
public FileVisitResult visitFileFailed(Path file, IOException exc) throws IOException {
System.err.println("Failed to visit file: " + file);
return FileVisitResult.CONTINUE;
}
});
} catch (IOException e) {
e.printStackTrace();
}
}
}
```
在上面的示例中,首先创建一个`Path`对象,表示要遍历的文件夹路径。然后,使用`Files.walkFileTree()`方法来遍历该文件夹。`walkFileTree()`方法接受两个参数:要遍历的文件夹路径和一个实现了`FileVisitor`接口的对象。
在`FileVisitor`接口的实现中,可以重写以下方法来处理遍历过程中的文件和目录:
- `visitFile(Path file, BasicFileAttributes attrs)`: 处理访问到的文件。
- `preVisitDirectory(Path dir, BasicFileAttributes attrs)`: 处理访问到的目录。
- `visitFileFailed(Path file, IOException exc)`: 处理访问文件失败的情况。
在示例中,我们简单地打印出访问到的文件和目录的路径。`FileVisitResult.CONTINUE`表示继续遍历,`FileVisitResult.TERMINATE`表示终止遍历。
请注意,`Files.walkFileTree()`方法会递归地遍历文件夹及其子文件夹中的所有内容,包括文件和目录。如果遍历的文件夹比较大或层级比较深,可能需要考虑性能和资源消耗的问题。