我正在尝试创建一个搜索方法,它需要一个路径,搜索其文件夹和目录,并打印出文件。最后,我希望它能够打印所有文件的数量。
这是我的代码:
public static void main(String[] args) {
search("C:\\Program Files (x86)\\Adobe");
}
public static void search(String folderpath){
File directory = new File(folderpath);
int numberOfFiles = 0;
for (File element : directory.listFiles()){
if(element.isDirectory()){
search(element.getAbsolutePath());
}
else{
numberOfFiles++;
System.out.println(element);
}
};
System.out.println(numberOfFiles);
};
结果如下:
folder
1
2
3
folder2
1
folder3
4
5
它永远不会为numberOfFiles
提出一个最终数字。
有没有人知道如何阻止它从每个文件夹打印numberOfFiles
,并在最后打印一次?
答案 0 :(得分:4)
您正在计算当前文件夹中的文件数并将其存储在本地变量中。由于该方法是递归的,因此只能获取当前正在检查的文件夹的文件数。
尝试返回当前文件夹中的文件数加上每个子文件夹中的文件数。然后,在客户端方法中,根据需要使用结果。
以下是代码的外观:
public static void main(String[] args) {
String pathToInspect = "C:\\Program Files (x86)\\Adobe"
int numberOfFiles = search(pathToInspect);
System.out.println("Number of files in " + pathToInspect + ": " + numberOfFiles);
}
//changed return type from void to int
public static int search(String folderpath) {
File directory = new File(folderpath);
int numberOfFiles = 0;
for (File element : directory.listFiles()) {
if(element.isDirectory()) {
//add the number of files of subfolder
numberOfFiles += search(element.getAbsolutePath());
} else {
numberOfFiles++;
}
}
//return number of files found
return numberOfFiles;
}
答案 1 :(得分:3)
你的方法是递归的,这是一个好主意,但是你不能通过将它放在方法本身(至少这样)来在递归结束时写一些东西。
所以,这是一个可能的纠正。使search
方法计算其中有多少文件(直接文件和子文件中的文件)。
public static void main(String[] args) {
System.out.println("# of files "+search("C:\\Program Files (x86)\\Adobe"));
}
public static int search(String folderpath){
File directory = new File(folderpath);
int numberOfFiles = 0;
for (File element : directory.listFiles()){
if (element.isDirectory()) { // count the files for this subdir
numberOfFiles += search(element.getAbsolutePath());
}
else { // one more file
numberOfFiles++;
System.out.println(element);
}
}
// return the number of files for this dir and its sub dirs
return numberOfFiles;
}