JAVA遍歷文件下的全部文件和文件夾數組
@Test
public void traverseFolder1( ) {
String path = "D:\\TEST";
int fileNum = 0;
int folderNum = 0;
int foldeNum = 0;
File file = new File(path);
if (file.exists()) {
LinkedList<File> list = new LinkedList<File>();spa
//list()方法是返回某個目錄下的全部文件和目錄的文件名,返回的是String數組code
//listFiles()方法是返回某個目錄下全部文件和目錄的絕對路徑,返回的是File數組
File[] files = file.listFiles();
for (File file2 : files) {
if (file2.isDirectory()) {
System.out.println("文件夾:" + file2.getAbsolutePath());
list.add(file2);
foldeNum++;
} else {
System.out.println("文件:" + file2.getAbsolutePath());
fileNum++;
}
}
File temp_file;
while (!list.isEmpty()) {
temp_file = list.removeFirst();//刪除第一個元素,也就是找到數組中的第一個元素返回一個File去判斷,說白了就是循環分別找到每一個文件下面對應的是文件仍是文件夾,若是循環下一級仍是文件夾則繼續循環直到結束(思想就是一層一層去判斷查找知道找到全部的文件和文件夾,不明白看下面的例子。)
files = temp_file.listFiles();
for (File file2 : files) {
if (file2.isDirectory()) {//若是是個目錄(文件夾)則返回true
System.err.println("文件夾:" + file2.getAbsolutePath());
list.add(file2);
folderNum++;
} else {//輸出文件
System.out.println("文件:" + file2.getAbsolutePath());//返回文件的完整路徑。
fileNum++;
}
}
}
} else {
System.out.println("文件不存在!");
}
System.out.println("文件夾共有:" + folderNum + ",文件共有:" + fileNum);
}blog
例子:遞歸
LinkedList list=new LinkedList();
list.add("a");
list.add(1);
list.add('b');
String kk=(String) list.removeFirst(); // (String) 這表明強制轉換 原理同上
char k=(char) list.removeLast();//刪除最後一個元素
System.out.println(kk);
System.out.println(k);
}
}
結果爲 a b
rem
//使用遞歸get
public void traverseFolder2(String path) { File file = new File(path); if (file.exists()) { File[] files = file.listFiles(); if (null == files || files.length == 0) { System.out.println("文件夾是空的!"); return; } else { for (File file2 : files) { if (file2.isDirectory()) { System.out.println("文件夾:" + file2.getAbsolutePath()); traverseFolder2(file2.getAbsolutePath()); } else { System.out.println("文件:" + file2.getAbsolutePath()); } } } } else { System.out.println("文件不存在!"); } }