「创作开运礼」Java之使用递归进行文件搜索
各位小伙伴们大家好,在之前的文章中小编介绍了「创作开运礼」Java之递归打印多级目录,这次小编要介绍的是使用递归进行文件搜索。
代码如下:
import java.io.File;
public class Demo04Recurison {
public static void main(String args[]) {
File file=new File("D:programmingCisco Packet Tracer");
getAllFile(file);
}
/*定义一个方法,参数传递File类型的目录
方法中对目录进行遍历*/
public static void getAllFile(File dir) {
File[] files=dir.listFiles();
for(File f:files) {
//对遍历得到的File对象f进行判断,判断是否是文件夹
if(f.isDirectory()) {
getAllFile(f);
}else {
//只要.pkt结尾的文件
//1.把File对象f,转为字符串对象
String s=f.getName();
//String name=f.gatName和String s=f.toString();也行
//把字符串,转换为小写
s=s.toLowerCase();
//2.调用String类中的方法endsWitch判断字符串是否以.pkt结尾
boolean b=s.endsWith(".pkt");
//3.如果以.java结尾的文件,则输出
if(b) {
System.out.println(f);
}
}
}
}
}
其实我们还可以玩一个链式编程,代码如下:
public class Demo04Recurison {
public static void main(String args[]) {
File file=new File("D:programmingCisco Packet Tracer");
getAllFile(file);
}
/*定义一个方法,参数传递File类型的目录
方法中对目录进行遍历*/
public static void getAllFile(File dir) {
File[] files=dir.listFiles();
for(File f:files) {
//对遍历得到的File对象f进行判断,判断是否是文件夹
if(f.isDirectory()) {
getAllFile(f);
}else {
if(f.getName().toLowerCase().endsWith(".pkt")) {//链式编程
System.out.println(f);
}
}
}
}
}
关于,使用递归进行文件搜索,其实和使用递归打印多级目录差不多,只是后面添加了字符串的转换还有String类中的toLowerCase()方法和endsWith()方法。小编就先说到这里,希望这篇文章可以帮到大家,也欢迎各位小伙伴补充和纠错。
图片来自网络,如有侵权,请联系作者删除