Java文件IO学习笔记(四)-查找文件

在文件系统中存在很多文件夹和文件,为了快速地从一个文件结构中找出指定类型的所有文件,我们使用文件类型的过滤器,方便对文件夹或文件进行过滤。
运用文件过滤器对文件进行查找的技术要点如下:
文件类型过滤器:FileFilter,在文件拷贝、移动、删除和压缩时,指定多个文件类型、修改时间、大小限制、覆盖条件、是否包含子目录等条件进行过滤。

package core;

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 File[] searchFile(File folder, final String keyword) {// 递归查找包含关键字的文件
        // 运用内部匿名类获得文件
        File[] subFolders = folder.listFiles(new FileFilter() {
            public boolean accept(File pathname) { // 实现FileFilter类accept方法
                if (pathname.isFile()) // 如果是文件
                    countFiles++;
                else // 如果是目录
                    countFolders++;
                if (pathname.isDirectory() || (pathname.isFile() && pathname.getName().contains(keyword))) // 目录或文件包含关键字
                    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) {
        File folder = new File("/Users/**/test/createFile/"); // 默认目录  **是一级文件目录
        String keyword = "temp";
        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()+" ");//显示文件绝对路径
        }
    }

}

这里写图片描述
源程序解读
(1)main()方法声明一个默认目录和关键字,用来在默认目录中查找包含关键字的文件或文件夹。调用searchFile()方法获得指定的文件集。循环遍历将文件中的文件的绝对路径输出到控制台。
(2)searchFile()方法运用内部匿名类获得文件集合(这里还没有运用关键字keyword,只是单纯地统计文件和文件夹的个数)。在内部匿名类中,必须实现FileFilter接口的accept()方法,此方法主要主要统计目录中文件夹与文件的个数,
(3)下一步便是搜索文件夹或文件中是否包含指定的关键字,获得包含关键字的文件夹和文件。
(4)再接着循环遍历文件集,文件集合中的文件直接存入声明的结合中,文件集中的文件夹则需要递归调用searchFile()方法,将文件夹中的文件遍历保存在集合中。再声明一个新的文件集,将集合中的元素数组化保存到新的文件集中。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 文件拆分是将一个大文件分成多个小文件的过程,这在处理大文件时非常有用。在Java中,可以使用文件字节IO流来实现文件拆分。具体步骤如下: 1. 打开要拆分的文件,创建一个输入流对象。 2. 创建一个输出流对象,用于写入拆分后的文件。 3. 定义一个缓冲区,用于存储读取的数据。 4. 循环读取文件中的数据,每次读取一定大小的数据,将其写入输出流中。 5. 当读取的数据量达到指定大小时,关闭当前输出流,创建一个新的输出流,继续写入数据。 6. 循环结束后,关闭输入流和输出流。 需要注意的是,拆分后的文件名可以根据需要进行命名,可以使用数字、字母或其他符号来区分不同的文件。同时,拆分后的文件大小也需要根据实际需求进行设置,一般建议不要超过2GB。 ### 回答2: Java是一门广泛应用的编程语言,涵盖了众多领域,其中文件输入输出是其中之一。文件字节IO流的文件拆分是文件处理中的一项重要功能,在Java中,常用的文件处理类库是java.io库,它包含了Java文件输入输出所需要的各种类,例如File类、FileReader类、FileWriter类、BufferedReader类、InputStream类、OutputStream类等。 Java文件字节IO流的文件拆分主要实现通过读取一个大文件,然后将其分割成小的文件块,以便于更好的管理文件,便于数据传输和存储。这种操作依赖于Java的二进制位操作,它的流程如下: 1. 指定待拆分的文件 通过File类下的File对象指定待拆分的文件。 2. 获取待拆分文件的长度 通过File对象的length()方法获取待拆分文件的长度,以便于下一步的拆分操作。 3. 打开输入流 通过InputStream类中的FileInputStream对象打开待拆分文件的输入流,以读取文件内容。 4. 拆分待处理文件 使用byte[]数组作为缓存区读取待处理文件中的内容,并将它分割成小的文件块。 5. 写入分割文件 通过OutputStream类中的FileOutputStream对象打开文件的输出流,将分割的文件块写入新的文件中(例如:文件名末尾加以排序数字)。 6. 关闭输入输出流 操作完成后,关闭输入输出流释放文件资源,避免内存泄漏。 文件字节IO流的文件拆分可以适用于很多场景,例如:大型多媒体文件的存储及快速传输、分散式文件处理场景等。在Java中,我们可以根据自己的需要,使用java.io库中的File类、InputStream类、OutputStream类等API进行相关操作。 ### 回答3: Java输入输出(I/O)是Java编程中重要的一个方面。I/O是程序与外部环境交互的重要方式,它允许程序从磁盘文件或其他设备中读取数据,并将计算结果写回磁盘或其他设备。在Java I/O中,文件字节IO流是常用的操作之一。 文件字节IO流是对文件进行字节级别操作的输入输出流。它以字节为单位进行读取和写入文件,每次读取和写入的长度是固定的,一般为1个字节或多个字节。 文件拆分是文件字节流IO操作中的一种常见应用。文件拆分是将文件按照一定的规则分解成多个文件的过程。例如,将一个大文件分成多个小文件,便于存储和传输。文件拆分在数据处理、数据传输等领域都有广泛的应用。 Java中实现文件拆分可以使用文件字节IO流。具体实现可以采用以下伪代码: 1. 打开原文件,创建文件字节输入流; 2. 创建多个文件字节输出流,每个输出流对应一个拆分后的文件; 3. 读取原文件,逐个字节分别写入每个输出流; 4. 当一个拆分后的文件大小达到限制值时,关闭该输出流,创建一个新的输出流继续写入; 5. 当原文件读取完毕时,关闭所有输出流,完成文件拆分。 这里需要考虑的一些问题是如何确定拆分后每个文件的大小,如何命名新的拆分文件等。 在编写文件拆分程序时,需要注意文件拆分的合法性。例如,在分解文件时需要根据文件格式和业务需求来确定分解规则,保证分解后的文件是合法的。同时还需要考虑拆分后的文件如何合并的问题。 综上所述,文件字节IO流的文件拆分操作是Java I/O编程中常见的操作之一。实现文件拆分需要充分考虑拆分规则和文件合法性等问题。在实际开发中,我们可以根据具体需求,结合其他API来实现更多复杂的文件操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值