在java中如何遍历某个路径下的所有文件夹和文件
2013-07-08 16:02
543 查看
我们要遍历所有的路径,需要使用到java.io.File类,该类中有一个方法File[] listFiles();可以返回该文件下面所包含的所有子文件,String
getPath();返回文件的全名称(包括路径),String getName(); 返回文件名。
首先,我们先来遍历一下D盘根目录下所有的子文件:
public static void fileList() {
File file=new File("d:/");
File[] files = file.listFiles();
if (files != null) {
for (File f : files) {
System.out.println(f.getPath());
}
}
}
对此,我们肯定不满足,我们需要遍历D盘下所有的文件和文件夹,而不是根目录下的文件夹,这个时候我们需要使用到递归:
public static void fileList(File file) {
File[] files = file.listFiles();
if (files != null) {
for (File f : files) {
System.out.println(f.getPath());
fileList(f);
}
}
}
然后在主函数中调用:
public static void main(String[] args) {
File file=new File("d:/");
fileList(file);
}
结果是不是能令你满意呢?显然,输出的都是全路径,我们可以对我们的递归函数做如下改进:
public static void fileList(File file,int node) {
node++;
File[] files = file.listFiles();
if (files != null) {
for (File f : files) {
for(int i=0;i<node;i++){
if(i==node-1){
System.out.print("├");
}
else{
System.out.print(" ");
}
}
System.out.println(f.getName());
fileList(f,node);
}
}
}
然后再次在主函数中调用:
public static void main(String[] args) {
File file=new File("d:/");
fileList(file,0);
}
得到的结果是一个类似树状的结构,如果你对此还不满意,可以尝试给JTree上添加节点,可以做到和资源管理器中一样的结构。
getPath();返回文件的全名称(包括路径),String getName(); 返回文件名。
首先,我们先来遍历一下D盘根目录下所有的子文件:
public static void fileList() {
File file=new File("d:/");
File[] files = file.listFiles();
if (files != null) {
for (File f : files) {
System.out.println(f.getPath());
}
}
}
对此,我们肯定不满足,我们需要遍历D盘下所有的文件和文件夹,而不是根目录下的文件夹,这个时候我们需要使用到递归:
public static void fileList(File file) {
File[] files = file.listFiles();
if (files != null) {
for (File f : files) {
System.out.println(f.getPath());
fileList(f);
}
}
}
然后在主函数中调用:
public static void main(String[] args) {
File file=new File("d:/");
fileList(file);
}
结果是不是能令你满意呢?显然,输出的都是全路径,我们可以对我们的递归函数做如下改进:
public static void fileList(File file,int node) {
node++;
File[] files = file.listFiles();
if (files != null) {
for (File f : files) {
for(int i=0;i<node;i++){
if(i==node-1){
System.out.print("├");
}
else{
System.out.print(" ");
}
}
System.out.println(f.getName());
fileList(f,node);
}
}
}
然后再次在主函数中调用:
public static void main(String[] args) {
File file=new File("d:/");
fileList(file,0);
}
得到的结果是一个类似树状的结构,如果你对此还不满意,可以尝试给JTree上添加节点,可以做到和资源管理器中一样的结构。
相关文章推荐
- java 如何递归遍历一个文件夹下的所有文件
- java.io.File类基本使用——遍历某路径的所有文件夹及文件
- java题-如何递归遍历一个文件夹下的所有文件
- JAVA 一个简单的文件写入代码(遍历文件夹获取所有文件、写入缓冲池、获取文件绝对路径、按后缀名过滤文件)
- java 如何递归遍历一个文件夹下的所有文件
- c#如何实现对指定路径文件夹的遍历并复制里面所有文件到指定路径
- Java中如何利用File类递归的遍历指定目录中的所有文件和文件夹
- JAVA 遍历文件夹下的所有文件(递归调用和非递归调用)
- cocos2d-x 如何读取遍历文件夹下的所有文件
- Java 遍历文件夹下的所有文件和文件夹
- java获取指定路径下的所有文件夹和文件名称路径
- java遍历一个文件夹中的所有文件
- 如何利用Java遍历所有的指定文件目录下的所有文件
- java遍历文件夹下所有的文件
- JS如何遍历一个文件夹下的所有文件与目录
- java递归读取文件夹中的所有文件以及路径
- JAVA遍历一个文件夹中的所有文件
- JS如何遍历一个文件夹下的所有文件与目录(转)
- JAVA遍历一个文件夹中的所有文件
- 遍历文件夹找出所有.java文件(递归)