如何在Java中以递归方式列出文件夹中的所有文件?
发布于 2008-10-10 00:45:14
不确定要如何表示树?不管怎样,这里有一个使用递归扫描整个子树的例子。文件和目录的处理方式是一样的。请注意,对于非目录,File.listFiles()将返回null。
public static void main(String[] args) {
Collection<File> all = new ArrayList<File>();
addTree(new File("."), all);
System.out.println(all);
}
static void addTree(File file, Collection<File> all) {
File[] children = file.listFiles();
if (children != null) {
for (File child : children) {
all.add(child);
addTree(child, all);
}
}
}
Java7提供了一些改进。例如,DirectoryStream一次只提供一个结果-调用者不再需要等待所有I/O操作完成后才执行操作。这允许增量GUI更新、提前取消等。
static void addTree(Path directory, Collection<Path> all)
throws IOException {
try (DirectoryStream<Path> ds = Files.newDirectoryStream(directory)) {
for (Path child : ds) {
all.add(child);
if (Files.isDirectory(child)) {
addTree(child, all);
}
}
}
}
请注意,可怕的null返回值已被IOException替换。
Java7还提供了一个tree walker
static void addTree(Path directory, final Collection<Path> all)
throws IOException {
Files.walkFileTree(directory, new SimpleFileVisitor<Path>() {
@Override
public FileVisitResult visitFile(Path file, BasicFileAttributes attrs)
throws IOException {
all.add(file);
return FileVisitResult.CONTINUE;
}
});
}
发布于 2008-10-09 20:38:21
import java.io.File;
public class Test {
public static void main( String [] args ) {
File actual = new File(".");
for( File f : actual.listFiles()){
System.out.println( f.getName() );
}
}
}
它模糊地显示文件和文件夹。
请参阅File类中的方法来对它们进行排序或避免目录打印等。
发布于 2008-10-10 15:54:33
您还可以使用FileFilter
接口过滤出您想要的内容。最好在创建实现它的匿名类时使用它:
import java.io.File;
import java.io.FileFilter;
public class ListFiles {
public File[] findDirectories(File root) {
return root.listFiles(new FileFilter() {
public boolean accept(File f) {
return f.isDirectory();
}});
}
public File[] findFiles(File root) {
return root.listFiles(new FileFilter() {
public boolean accept(File f) {
return f.isFile();
}});
}
}
https://stackoverflow.com/questions/189094
复制相似问题