Java 获取目录以及子目录下的sql文件

问题:得到指定目录以及子目录下指定后缀名的文件,这里是得到sql文件

项目文件结构是这样式的

比如我传参F:/sql  需要得到所有文件夹中的sql文件。

解决方案:

用到了FilenameFilter  以及 递归。

 

首先我们实现FilenameFiltre接口,重写accept方法

import java.io.File;
import java.io.FilenameFilter;

public class SqlFileFilter implements FilenameFilter {

    @Override
    public boolean accept(File dir, String name) {

        if (dir.isDirectory())
            return true;
        if (name.toLowerCase().endsWith(".sql"))
            return true;
        else
            return false;

    
    }

}

再者,我们写一个通用的递归调用方法

    public static List<File> listFile(File dir, FilenameFilter ff,
            boolean recursive) {
        List<File> list = new ArrayList<File>();
        File[] files = dir.listFiles(ff);
        if (files != null && files.length > 0) {
            for (File f : files) {
                // 如果是文件,添加文件到list中
                if (f.isFile()) {
                    list.add(f);
                }
                // 获取子目录中的文件,添加子目录中的经过过滤的所有文件添加到list
                else if (recursive) {
                    list.addAll(listFile(f, ff, true));
                }
            }
        }
        return list;
    }

 

其中第三个参数表示是否递归。

 

测试:

    public static void main(String[] args) {

        File file = new File("F:/javaresource/checktools/sql/");

        List<File> files = listFile(file, new SqlFileFilter(), true);

        for (File s : files) {
            System.out.println(s);
        }
    }

结果:

 

转载于:https://www.cnblogs.com/ydemo/p/10481969.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值