Java递归扫描文件夹下特定后缀名或者前缀的文件

一.业务需求部分

        在最近工作中,需要用程序来处理一个服务器地址的文件夹下的特定后缀名的文件,需要对这个文件夹里面的部分文件做转移处理,所以首先想到的就是用递归扫描文件夹啊!下面开始代码分析递归扫描文件夹:

二.代码部分

方法一:

1.下面的代码中用的是以后缀名进行扫描

package com.yinxin.control;

import java.io.File;
import java.io.FileFilter;
import java.util.ArrayList;
import java.util.List;

public class Client {
	static int countFiles = 0;// 声明统计文件个数的变量
	static int countFolders = 0;// 声明统计文件夹的变量

	public static File[] searchFile(File folder, final String keyWord) {// 递归查找包含关键字的文件

		File[] subFolders = folder.listFiles(new FileFilter() {// 运用内部匿名类获得文件
					@Override
					public boolean accept(File pathname) {// 实现FileFilter类的accept方法
						if (pathname.isFile())// 如果是文件
							countFiles++;
						else
							countFolders++;// 如果是目录
						if (pathname.isDirectory()
								|| (pathname.isFile() && pathname.getName()
										.toLowerCase()
										.contains(keyWord.toLowerCase())))// 目录或文件包含关键字
							return true;
						return false;
					}
				});

		List<File> result = new ArrayList<File>();// 声明一个集合
		for (int i = 0; i < subFolders.length; i++) {// 循环显示文件夹或文件
			if (subFolders[i].isFile()) {// 如果是文件则将文件添加到结果列表中
				result.add(subFolders[i]);
			} else {// 如果是文件夹,则递归调用本方法,然后把所有的文件加到结果列表中
				File[] foldResult = searchFile(subFolders[i], keyWord);
				for (int j = 0; j < foldResult.length; j++) {// 循环显示文件
					result.add(foldResult[j]);// 文件保存到集合中
				}
			}
		}

		File files[] = new File[result.size()];// 声明文件数组,长度为集合的长度
		result.toArray(files);// 集合数组化
		return files;
	}

	public static void main(String[] args) {// java程序的主入口处
		File folder = new File("E:\\totest");// 默认目录
		String keyword = ".dat";
		if (!folder.exists()) {// 如果文件夹不存在
			System.out.println("目录不存在:" + folder.getAbsolutePath());
			return;
		}
		File[] result = searchFile(folder, keyword);// 调用方法获得文件数组
		System.out.println("在 " + folder + " 目录下所有子文件下查找后缀为" + keyword+"的所有文件");
		System.out.println("查找了" + countFiles + " 个文件," + countFolders
				+ " 个文件夹,共找到 " + result.length + " 个符合条件的文件:");
		for (int i = 0; i < result.length; i++) {
			File file = result[i];
			System.out.println(file.getAbsolutePath() + " ");// 显示文件绝对路径
		}
	}

}

2.文件地址:

 3.展示效果图:

方法二:

 1.通过文件后缀名进行找文件

package com.yinxin.control;

import java.io.File;

public class Test {
	public static void main(String[] args) {
		File file = new File("E:" + File.separator + "totest");
		finDiGui(file);
	}
 
	public static void finDiGui(File file) {
		// 判断是否为文件夹
		if (file.isDirectory()) {
			File[] listFiles = file.listFiles();
			// 执行操作
			for (File f : listFiles) {
				finDiGui(f);  //递归调用
			}
		}
		//用file的endsWith()方法是通过后缀去筛选 
		if (file.getName().endsWith(".dat")) {
			System.out.println(file);
		}
	}
}

效果图:

2.通过文件前缀进行查找文件

public class Test {
	
	public static void finDiGui(File file) {
		// 判断是否为文件夹
		if (file.isDirectory()) {
			File[] listFiles = file.listFiles();
			// 执行操作
			for (File f : listFiles) {
				finDiGui(f);  //递归调用
			}
		}
		//通过它的前缀用startsWith()方法去筛选
		if (file.getName().startsWith("NXJZGRZH")) {
			System.out.println(file);
		}
	}
	
	public static void main(String[] args) {
		File file = new File("E:" + File.separator + "totest");
		finDiGui(file);
	}
}

 效果图:

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

醉梦洛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值