Javaでフォルダー内のすべてのファイルを再帰的に一覧表示するにはどうすればよいですか?
どのようにツリーを表現したいのかわかりませんか?とにかく、再帰を使用してサブツリー全体をスキャンする例があります。ファイルとディレクトリは同様に扱われます。 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は 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;
}
});
}
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クラスのメソッドを参照して、それらを順序付けするか、ディレクトリの印刷などを避けてください。
Apache Commons FileUtils(listFiles、iterateFilesなど)を確認してください。あなたがしたいことをし、またフィルターを適用するための素敵な便利な方法。
http://commons.Apache.org/io/api-1.4/org/Apache/commons/io/FileUtils.html
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();
}});
}
}
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:\
ツリー構造を視覚化することは、私にとって最も便利な方法でした:
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;
}
JDK7では、「その他のNIO機能」には、ビジターパターンをファイルツリーまたはディレクトリの直接のコンテンツに適用するメソッドが必要です。繰り返し処理する前に、潜在的に巨大なディレクトリですべてのファイルを見つける必要はありません。