如何在Java中递归列出文件夹中的所有文件?
答案 0 :(得分:71)
不确定您想要如何表示树?无论如何这里是一个使用递归扫描整个子树的例子。文件和目录是相同的。请注意,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);
}
}
}
Java 7提供了一些改进。例如,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);
}
}
}
}
请注意,dreaded null返回值已被IOException替换。
Java 7还提供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;
}
});
}
答案 1 :(得分: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类中的方法来对它们进行排序或避免目录打印等。
答案 2 :(得分:18)
查看Apache Commons FileUtils(listFiles,iterateFiles等)。很方便的方法,可以做你想做的事情,也可以应用过滤器。
http://commons.apache.org/io/api-1.4/org/apache/commons/io/FileUtils.html
答案 3 :(得分:6)
您还可以使用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();
}});
}
}
答案 4 :(得分:2)
public static void directory(File dir) {
File[] files = dir.listFiles();
for (File file : files) {
System.out.println(file.getAbsolutePath());
if (file.listFiles() != null)
directory(file);
}
}
此处dir
是要扫描的目录。例如c:\
答案 5 :(得分:1)
可视化树形结构对我来说是最方便的方式:
public static void main(String[] args) throws IOException {
printTree(0, new File("START/FROM/DIR"));
}
static void printTree(int depth, File file) throws IOException {
StringBuilder indent = new StringBuilder();
String name = file.getName();
for (int i = 0; i < depth; i++) {
indent.append(".");
}
//Pretty print for directories
if (file.isDirectory()) {
System.out.println(indent.toString() + "|");
if(isPrintName(name)){
System.out.println(indent.toString() + "*" + file.getName() + "*");
}
}
//Print file name
else if(isPrintName(name)) {
System.out.println(indent.toString() + file.getName());
}
//Recurse children
if (file.isDirectory()) {
File[] files = file.listFiles();
for (int i = 0; i < files.length; i++){
printTree(depth + 4, files[i]);
}
}
}
//Exclude some file names
static boolean isPrintName(String name){
if (name.charAt(0) == '.') {
return false;
}
if (name.contains("svn")) {
return false;
}
//.
//. Some more exclusions
//.
return true;
}
答案 6 :(得分:0)
在JDK7中,“更多NIO功能”应该有方法将访问者模式应用于文件树或仅仅是目录的直接内容 - 在迭代它们之前无需查找潜在巨大目录中的所有文件。