`
tiwson
  • 浏览: 333494 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

Java递归搜索指定文件夹下的匹配文件

阅读更多
import java.io.File;
import java.util.ArrayList;
import java.util.List;
import java.util.Queue;

/**
 * @author tiwson 2010-06-02
 * 
 */
public class FileSearcher {

	/**
	 * 递归查找文件
	 * @param baseDirName  查找的文件夹路径
	 * @param targetFileName  需要查找的文件名
	 * @param fileList  查找到的文件集合
	 */
    public static void findFiles(String baseDirName, String targetFileName, List fileList) {
        /**
         * 算法简述:
         * 从某个给定的需查找的文件夹出发,搜索该文件夹的所有子文件夹及文件,
         * 若为文件,则进行匹配,匹配成功则加入结果集,若为子文件夹,则进队列。
         * 队列不空,重复上述操作,队列为空,程序结束,返回结果。
         */
        String tempName = null;
        //判断目录是否存在
        File baseDir = new File(baseDirName);
        if (!baseDir.exists() || !baseDir.isDirectory()){
            System.out.println("文件查找失败:" + baseDirName + "不是一个目录!");
        } else {
        	String[] filelist = baseDir.list();
    	    for (int i = 0; i < filelist.length; i++) {
    	    	File readfile = new File(baseDirName + "\\" + filelist[i]);
    	    	//System.out.println(readfile.getName());
    	        if(!readfile.isDirectory()) {
    	        	tempName =  readfile.getName(); 
                    if (FileSearcher.wildcardMatch(targetFileName, tempName)) {
                        //匹配成功,将文件名添加到结果集
                        fileList.add(readfile.getAbsoluteFile()); 
                    }
    	        } else if(readfile.isDirectory()){
    	        	findFiles(baseDirName + "\\" + filelist[i],targetFileName,fileList);
    	        }
    	    }
        }
    }
    
    /**
     * 通配符匹配
     * @param pattern    通配符模式
     * @param str    待匹配的字符串
     * @return    匹配成功则返回true,否则返回false
     */
    private static boolean wildcardMatch(String pattern, String str) {
        int patternLength = pattern.length();
        int strLength = str.length();
        int strIndex = 0;
        char ch;
        for (int patternIndex = 0; patternIndex < patternLength; patternIndex++) {
            ch = pattern.charAt(patternIndex);
            if (ch == '*') {
                //通配符星号*表示可以匹配任意多个字符
                while (strIndex < strLength) {
                    if (wildcardMatch(pattern.substring(patternIndex + 1),
                            str.substring(strIndex))) {
                        return true;
                    }
                    strIndex++;
                }
            } else if (ch == '?') {
                //通配符问号?表示匹配任意一个字符
                strIndex++;
                if (strIndex > strLength) {
                    //表示str中已经没有字符匹配?了。
                    return false;
                }
            } else {
                if ((strIndex >= strLength) || (ch != str.charAt(strIndex))) {
                    return false;
                }
                strIndex++;
            }
        }
        return (strIndex == strLength);
    }

    public static void main(String[] paramert) {
        //    在此目录中找文件
        String baseDIR = "d:/file"; 
        //    找扩展名为txt的文件
        String fileName = "*.txt"; 
        List resultList = new ArrayList();
        FileSearcher.findFiles(baseDIR, fileName, resultList); 
        if (resultList.size() == 0) {
            System.out.println("No File Fount.");
        } else {
            for (int i = 0; i < resultList.size(); i++) {
                System.out.println(resultList.get(i));//显示查找结果。 
            }
        }
    }


}
分享到:
评论
2 楼 niwowl 2014-11-03  
通配符!好!
1 楼 plawy 2014-05-26  
搞那么复杂干嘛?
哥几行代码搞定,还通用
/*简单说明下,files就是你需要的那个指定类型文件的file对象list,
*你需要知道具体文件名或者文件路径或者文件大小等,自己通过File的API去取,比如:file.getName();file.getAbsolutePath()……
*files:不要跟我说你直接传null啊
*suffixs:文件后缀,注意全是小写,不包含点,比如:rar,text等,支持* 或者空list,后缀lsit为空我就认为是不过滤后缀
* path:任意路径
*/
public static List<File> getAllFiles(List<File> files,
List<String> suffixs, String path) {
File fileT = new File(path);
if (fileT.exists()) {
if (fileT.isDirectory()) {
for (File f : fileT.listFiles()) {
files = getAllFiles(files, suffixs, f.getAbsolutePath());
}
} else {
//被没后缀的文件坑过,所以加了无后缀文件判断
if (suffixs.size() == 0
|| suffixs.contains("*")
|| (fileT.getName().indexOf(".") != -1 && suffixs
.contains(fileT.getName().split("\\.")[1]
.toLowerCase()))) {
files.add(fileT);
}
}
}
return files;
}

相关推荐

    递归删除指定类型的文件夹,递归删除指定类型的文件

    本主题主要探讨如何实现“递归删除指定类型的文件夹”和“递归删除指定类型的文件”,以及如何在文件夹内部进行深度搜索和深度删除。 首先,我们需要理解递归的概念。递归是一种解决问题的方法,它将一个问题分解为...

    JAVA程序递归方式搜索Windows文件夹源代码

    在Java编程中,递归是一种强大的技术,常用于解决复杂问题,例如遍历或搜索文件系统中的文件夹。本文将详细解析如何使用Java编写一个递归程序来搜索Windows文件夹,以及涉及到的相关知识点。 首先,我们需要理解...

    文件夹递归查询所有文件夹内容替换目标文本

    在这个场景中,批处理文件的作用是调用Java的jar包,启动程序并传递参数,以便遍历指定文件夹及其子文件夹中的所有文件。 接下来,我们来看看Java的jar包。jar(Java Archive)是Java平台中用于打包和分发软件的...

    java实现根据关键字查找所在文件夹的文件

    使用`File`类的`listFiles()`方法,可以获取指定目录下的所有文件和子文件夹。如果需要递归查找,还需要一个递归函数来遍历子文件夹。 ```java public File[] listFiles(File dir) { return dir.listFiles(); } `...

    打印当前文件夹下指定类型文件到文本文件

    标题"打印当前文件夹下指定类型文件到文本文件"描述的就是这样一个功能,它允许用户便捷地将一个目录下符合特定条件(比如扩展名)的文件信息导出为文本格式。接下来,我们将深入探讨如何实现这一功能,并涉及相关的...

    关于java递归文件,以及检索特定文件

    以下是一个简单的Java递归函数示例,用于遍历文件夹并查找特定文件: ```java import java.io.File; public class FileSearch { public static void main(String[] args) { String targetFileName = "targetFile...

    Java实现的模糊匹配某文件夹下的文件并删除功能示例

    使用 `File` 类的 `listFiles()` 方法可以获取给定路径下所有文件和子文件夹的数组。这使得我们能够遍历文件夹中的每一个文件或子文件夹。 3. **删除文件**: 删除文件的操作由 `deleteFile()` 方法完成。`File` ...

    FileFinder:Java 模块递归搜索文件夹中的文件。 仅查找文件名的完全匹配项,忽略大小写。 仅返回第一个匹配项

    递归搜索文件夹中文件的代码。 仅查找文件名的完全匹配项,忽略大小写。 仅返回第一个匹配项。 取决于 - java.io.File; - java.io.IOException; - org.apache.commons.io.FileUtils; 用 FileFinder ff = new ...

    遍历指定文件夹中的所有子目录和文件

    这段代码中,`os.walk()`函数会递归地遍历指定的`root_dir`目录及其所有子目录,每次返回一个三元组,包含当前目录名、子目录列表和当前目录下的文件列表。通过循环遍历这些信息,我们可以访问到每一个文件。 对于...

    文件夹搜索指定字符串软件

    标题中的“文件夹搜索指定字符串软件”是一款专用于在...总的来说,这款“文件夹搜索指定字符串软件”结合了Java编程、文件I/O、字符串处理、多线程、跨平台技术等多个IT领域的知识,是一个实用且技术含量较高的工具。

    遍历某文件夹下的 .txt 文件

    根据提供的文件标题、描述、标签以及部分内容,我们可以总结出与“遍历某文件夹下的 .txt ...通过上述知识点的学习,可以更好地理解如何在 Java 中遍历文件夹并处理其中的文件,特别是在针对特定文件类型的需求场景下。

    获取目录下所有文件和文件夹,并计算其MD5值,两个文件夹比较,得出被篡改的目录路径

    然后,通过比较这两个哈希表,找出只在一个文件夹中存在的元素,以及MD5值不匹配的文件,这些就是被篡改的文件或目录。这个过程可能涉及到深度优先搜索或广度优先搜索,具体取决于比较策略。 在实际应用中,这个...

    Java扫描文件夹下所有文件名

    Java扫描文件夹下所有文件名是Java编程语言中的一种常见操作,旨在实现对指定文件夹下的所有文件进行扫描和管理。该操作在实际应用中具有重要意义,例如在文档资源管理系统中,需要扫描文件夹下的所有文件以便进行...

    Android 遍历文件夹,搜索指定扩展名的文件

    通过对上述代码片段的分析,我们了解到了在Android环境下遍历文件夹并搜索指定扩展名文件的基本方法。这些方法涉及到了文件系统的访问、字符串处理、递归逻辑等多个方面。开发者可以根据自己的需求灵活调整遍历逻辑...

    java实现本地按照FTP服务器上目录结构创建文件夹下载文件

    在Java编程环境中,实现从FTP(File Transfer Protocol)服务器上按照其目录结构创建本地文件夹并下载文件是一项常见的任务。FTP是一种用于在网络上传输文件的标准协议,它允许用户从远程服务器上获取或发送文件。本...

    记录一下 Java 代码实现文件夹、文件的对比,主要包含 word、pdf、文本、图片等相关文件的对比计算,以及计算文本的相似率

    在Java编程中,对比文件夹和文件是一项常见的需求,尤其在文档管理和版本控制中。本篇文章将探讨如何使用Java实现这一功能,特别是针对word、pdf、文本和图片等类型的文件进行对比计算,以及如何计算文本的相似率和...

    读取固定路径文件夹下文件内容是否包含搜索的内容.rar

    标题和描述中提到的任务是关于在Java环境下,从固定路径的文件夹中读取文件内容,并检查这些内容是否包含特定的搜索字符串。这个任务涉及到文件I/O操作、文本处理以及可能的多文件处理。以下是一些相关的Java知识点...

    java文件搜索器(完整)

    【Java文件搜索器】是一个基于Java编程语言实现的实用工具,它允许用户在计算机的各个磁盘或指定的文件夹中快速查找特定的文件。这个应用程序利用了Java强大的I/O和文件操作功能,为用户提供了一个方便的方式来定位...

    根据关键字搜索文件夹

    这个小程序的功能是将指定的字符串添加到匹配文件的开头,进一步增强搜索结果的识别度。 首先,我们需要了解如何在编程中实现文件和目录的搜索。在大多数编程语言中,如Python、Java或C#,都有内置的库或API来处理...

Global site tag (gtag.js) - Google Analytics