「java文件夹递归遍历」java递归遍历目录

博主:adminadmin 2022-12-09 23:00:09 200

本篇文章给大家谈谈java文件夹递归遍历,以及java递归遍历目录对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

JAVA遍历一个文件夹中的所有文件---(递归)

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("文件不存在!");

}

}

扩展资料

public void traverseFolder1(String path) {      

int fileNum = 0, folderNum = 0;

File file = new File(path);      

if (file.exists()) {

LinkedListFile list = new LinkedListFile();

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();

files = temp_file.listFiles();              

for (File file2 : files) {                  

if (file2.isDirectory()) {

System.out.println("文件夹:" + file2.getAbsolutePath());

list.add(file2);

folderNum++;

} else {

System.out.println("文件:" + file2.getAbsolutePath());

fileNum++;

}

}

}

} else {

System.out.println("文件不存在!");

}

System.out.println("文件夹共有:" + folderNum + ",文件共有:" + fileNum);

}

参考资料:百度百科 Java

在java中如何遍历某个路径下的所有文件夹和文件

首先,我们先来遍历一下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;inode;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遍历指定文件夹下的所有子文件夹怎么操作?

import java.io.File ;\x0d\x0aimport java.io.IOException ;\x0d\x0apublic class FileDemo11{\x0d\x0apublic static void main(String args[]){\x0d\x0aFile my = new File("d:" + File.separator) ;// 操作路径,可以有外部参数决定的\x0d\x0aprint(my) ;\x0d\x0a}\x0d\x0apublic static void print(File file){// 递归调用\x0d\x0aif(file!=null){// 判断对象是否为空\x0d\x0aif(file.isDirectory()){// 如果是目录\x0d\x0aFile f[] = file.listFiles() ;// 列出全部的文件\x0d\x0aif(f!=null){// 判断此目录能否列出\x0d\x0afor(int i=0;i

回答于 2022-11-15

使用java递归方法遍历指定目录下所有子目录和子文件

import java.io.*;

import java.util.ArrayList;

import java.util.Iterator;

import java.util.List;

/**

* 读取目录及子目录下指定文件名的路径 并放到一个数组里面返回遍历

* @author zdz8207

*

*/

public class FileViewer {

public static void main(String[] args) {

//List arrayList = FileViewer.getListFiles("d:/com","html",true);

//读取d:/com下的以java 结尾的文件 如有子目录,包含之(后缀名为null则为所有文件)

//List arrayList = FileViewer.getListFiles("d:/com","java",true);

//经试验,后缀不能不填写,否则编译不通过,提示“FileViewer.java:17: 非法的表达式开始”。

//另外后缀为""时的情况需要 增加到IF 里去,否则 后缀为""时,不会显示所有文件

List arrayList = FileViewer.getListFiles("d:/com","",true);

if(arrayList.isEmpty())

{

System.out.println("没有符号要求的文件");

}

else

{

String message = "";

message += "符号要求的文件数:" + arrayList.size() + "\r\n";

System.out.println(message);

for (Iterator i = arrayList.iterator(); i.hasNext();)

{

String temp = (String) i.next();

System.out.println(temp);

message += temp + "\r\n";

}

//将显示的文件路径写到指定的文件里,若文件不存在,则提示IO异常

//java.io.FileNotFoundException: d:\ajax\menu.txt (系统找不到指定的路径。)

//如果 加个文件是否存在的判断,如不存在就在当前目录新建一个,则更好。

appendMethod("d:/menu.txt",message);

}

}

public static ListString fileList = new ArrayListString();

/**

*

* @param path 文件路径

* @param suffix 后缀名

* @param isdepth 是否遍历子目录

* @return

*/

public static List getListFiles(String path, String suffix, boolean isdepth)

{

File file = new File(path);

return FileViewer.listFile(file ,suffix, isdepth);

}

public static List listFile(File f, String suffix, boolean isdepth)

{

//是目录,同时需要遍历子目录

if (f.isDirectory() isdepth == true)

{

File[] t = f.listFiles();

for (int i = 0; i t.length; i++)

{

listFile(t[i], suffix, isdepth);

}

}

else

{

String filePath = f.getAbsolutePath();

System.out.println("suffix = "+suffix);

if(suffix =="" || suffix == null)

{

//后缀名为null则为所有文件

System.out.println("----------------");

fileList.add(filePath);

}

else

{

int begIndex = filePath.lastIndexOf(".");//最后一个.(即后缀名前面的.)的索引

String tempsuffix = "";

if(begIndex != -1)//防止是文件但却没有后缀名结束的文件

{

tempsuffix = filePath.substring(begIndex + 1, filePath.length());

}

if(tempsuffix.equals(suffix))

{

fileList.add(filePath);

}

System.out.println("|||||||||||||||||||");

}

}

return fileList;

}

/**

* 方法追加文件:使用FileWriter

* @param fileName

* @param content

*/

public static void appendMethod(String fileName, String content)

{

try

{

//打开一个写文件器,构造函数中的第二个参数true表示以追加形式写文件

FileWriter writer = new FileWriter(fileName, true);

writer.write(content + "\r\n");

writer.close();

}

catch (IOException e)

{

e.printStackTrace();

}

}

}

java 递归遍历文件夹

在main方法中填写要遍历的文件夹,就可以删除文件夹中的文件名以bmp和jpg结尾的文件。这个方法使用了递归思想

import java.io.*;

class FileTest

{

public static int cc=0;

public static void Sereach(File f)

{

if(f.isFile())

{

String str=f.getName().substring(f.getName().length()-4);

if(str.equals(".bmp")||str.equals(".jpg")||str.equals(".BMP")||str.equals(".JPG"))

{

f.delete();

System.out.println("删除"+f.getName());

cc++;

}

}

if(f.isDirectory())

{

File []ss=f.listFiles();

for(int i=0;iss.length;i++)

{

Sereach(ss[i]);

}

}

}

public static void main(String []args) throws Exception

{

File f=new File("D:\\picture");

Sereach(f);

System.out.println("一共删除了"+cc+"张bmp或jpg格式的图片");

}

}

关于java文件夹递归遍历和java递归遍历目录的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

The End

发布于:2022-12-09,除非注明,否则均为首码项目网原创文章,转载请注明出处。