当前位置:首页 > Java

java如何复制文件夹及文件

2026-02-05 11:09:53Java

使用 Files.copy 方法(Java NIO)

Java NIO 的 Files.copy 方法适合复制单个文件或空文件夹。对于非空文件夹,需递归处理子目录和文件。

java如何复制文件夹及文件

import java.nio.file.*;

public static void copyFolder(Path source, Path target) throws IOException {
    Files.walk(source).forEach(srcPath -> {
        try {
            Path destPath = target.resolve(source.relativize(srcPath));
            Files.copy(srcPath, destPath, StandardCopyOption.REPLACE_EXISTING);
        } catch (IOException e) {
            e.printStackTrace();
        }
    });
}

使用 Apache Commons IO 库

Apache Commons IO 的 FileUtils.copyDirectory 方法提供了更简洁的解决方案,需添加依赖:

java如何复制文件夹及文件

<dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.11.0</version>
</dependency>

代码示例:

import org.apache.commons.io.FileUtils;

FileUtils.copyDirectory(new File("sourcePath"), new File("targetPath"));

递归手动实现

若需不依赖第三方库,可手动实现递归复制:

import java.io.*;

public static void copyFolder(File source, File target) throws IOException {
    if (source.isDirectory()) {
        if (!target.exists()) target.mkdir();
        for (String file : source.list()) {
            copyFolder(new File(source, file), new File(target, file));
        }
    } else {
        try (InputStream in = new FileInputStream(source);
             OutputStream out = new FileOutputStream(target)) {
            byte[] buffer = new byte[1024];
            int length;
            while ((length = in.read(buffer)) > 0) {
                out.write(buffer, 0, length);
            }
        }
    }
}

注意事项

  • 目标文件夹需有写入权限。
  • 大文件建议使用缓冲流(如 BufferedInputStream)。
  • 符号链接需特殊处理,避免无限递归。
  • Java 7+ 推荐 NIO 方式,性能更优。

标签: 文件夹文件
分享给朋友:

相关文章

vue 实现文件目录

vue 实现文件目录

Vue 实现文件目录结构 Vue 项目通常采用模块化设计,合理的目录结构有助于代码维护和团队协作。以下是常见的 Vue 项目目录结构及说明: 基础目录结构(基于 Vue CLI 生成) proje…

vue文件底层实现

vue文件底层实现

Vue 文件的底层实现 Vue 单文件组件(SFC,即 .vue 文件)的底层实现依赖于 Vue 的编译工具链,主要包括 @vue/compiler-sfc 和构建工具(如 Vite 或 Webpac…

vue实现文件预览

vue实现文件预览

Vue 实现文件预览的方法 文件预览功能通常涉及图片、PDF、Office文档等多种格式的处理。以下是几种常见文件类型的实现方案: 图片预览 使用 <input type="file">…

vue实现文件分享

vue实现文件分享

Vue 实现文件分享功能 前端文件上传与展示 使用 Vue 和 Element UI 实现文件上传组件,允许用户选择文件并上传到服务器。 <template> <div>…

vue实现文件导入导出

vue实现文件导入导出

Vue 文件导入 在 Vue 中实现文件导入通常通过 <input type="file"> 元素结合 FileReader API 完成。 <template> <…

vue实现word文件预览

vue实现word文件预览

vue实现word文件预览的方法 在Vue项目中实现Word文件预览,可以通过以下几种方式: 使用mammoth.js库 mammoth.js是一个将.docx文件转换为HTML的JavaScrip…