java利用关键字实现查找文件

  • 输入指定关键字,在制定目录中查找包含关键字的文件,返回包含指定关键字的文件路径。

文件类型过滤器:FileFilter,在文件拷贝、移动、删除和压缩时,指定多个文件类型、修改时间、大小限制、覆盖条件、是否包含子目录等条件进行过滤。文件备份、中间文件清理等时非常便利。便利的履历管理功能,重复相同的操作时非常简便。操作前检索满足条件的文件,并估计所需容量,操作完成后可查看记录,完成情况一目了然。

package net.xsoftlab.baike;

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

//操作查找文件的类
public class TextSearchFile {
    static int countFiles = 0;// 声明统计文件个数的变量
    static int countFolders = 0;// 声明统计文件夹的变量 

 public static void main(String[] args) {// java程序的主入口处
        File folder = new File("E:/logs");// 默认目录
        String keyword = "x";
        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() + " ");// 显示文件绝对路径
        }
    }



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

// 运用内部匿名类获得文件
            @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>();
        // 声明一个集合
        // 循环显示文件夹或文件
            if (subFolders[i].isFile()) {// 如果是文件则将文件添加到结果列表中
                result.add(subFolders[i]);
        // 如果是文件夹,则递归调用本方法,然后把所有的文件加到结果列表中
                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;
    }


}

原文链接:http://baike.xsoftlab.net/view/46.html#1

  • 4
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值