62

Javaでフォルダ内のすべてのファイルを再帰的にリストするにはどうすればよいですか?

4

6 に答える 6

74

ツリーをどのように表現したいかわかりませんか? とにかく、再帰を使用してサブツリー全体をスキャンする例を次に示します。ファイルとディレクトリは同じように扱われます。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は一度に 1 つの結果を提供します。呼び出し元は、すべての 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 に置き換えられたことに注意してください。

Java 7 にはツリー ウォーカーも用意されています。

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-10T00:45:14.347 に答える
23
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() );
        }
    }
}

ファイルとフォルダが不明瞭に表示されます。

ファイルクラスのメソッドを参照して、それらを注文するか、ディレクトリの印刷などを回避してください。

http://java.sun.com/javase/6/docs/api/java/io/File.html

于 2008-10-09T20:38:21.367 に答える
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();
            }});
    }
}
于 2008-10-10T15:54:32.597 に答える
3
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:\

于 2013-02-27T11:21:05.983 に答える
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;
}
于 2012-05-08T10:06:43.620 に答える
0

JDK7 では、「より多くの NIO 機能」に、ファイル ツリーまたはディレクトリの直接のコンテンツにビジター パターンを適用するメソッドが必要です。それらを反復処理する前に、潜在的に巨大なディレクトリ内のすべてのファイルを見つける必要はありません。

于 2008-10-10T08:13:16.987 に答える