本例演示了“文件遍历时,指定遍历的层数”的实现方式。
1. 例子代码:
package com.myjava.test;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
public class JavaTest {
/**
* @param args
*/
public static void main(String[] args) {
JavaTest jt = new JavaTest();
String path = "E:\\filetest";
File file = new File(path);
try {
jt.getFile(file, 0);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
int mDirLevel = 2; //层数
private void getFile(File file, int dirLevel) throws Exception {
if (mDirLevel != -1 && dirLevel > mDirLevel) {
dirLevel = 0;
return;
}
if (file == null) {
return;
}
if (file.exists()) {
if (file.isFile()) {
//do what?
System.out.println("file:" + file.getAbsolutePath());
} else {
// 获得当前文件夹下的所有子文件和子文件夹
File files[] = file.listFiles();
// 循环处理每个对象
if (files == null) {
return;
}
for (int i = 0; i < files.length; i++) {
// 递归调用,处理每个文件对象
getFile(files[i], dirLevel +1);
}
}
}
}
}
2. 测试结果:
file:E:\filetest\f.txt
file:E:\filetest\f1\新建文本文档 - 副本.txt
file:E:\filetest\f1\新建文本文档.txt
file:E:\filetest\f1 - 副本\新建文本文档.txt