博客
关于我
java_递归复制目录及目录下的文件
阅读量:237 次
发布时间:2019-03-01

本文共 4429 字,大约阅读时间需要 14 分钟。

package experiment8.exp1;import java.io.File;import java.io.IOException;import java.nio.file.Files;import java.util.Scanner;public class CopyDirectoryAndFiles{       public static void main(String[] args) throws IOException {           Scanner scanner = new Scanner(System.in);        System.out.println("输入被复制源目录名:");        String sourceDirectory = scanner.nextLine();        System.out.println("输入副本目标目录名");        String destinationDirectory = scanner.nextLine();        /*调用递归复制函数.*/        copyDir(sourceDirectory, destinationDirectory);    }/*本递归复制函数具有检查并创建新目录的能力,*/    static void copyDir(String oldPath, String newPath) throws IOException {           File file = new File(oldPath);        String[] filePath = file.list();/*//当前路径下存在的目录名和文件名的数组.比较建议用list方法,不推荐用listFile方法,因为后面        要通过连接目录名来创建新目录,用字符串比较方便.*/        /*检查新目录是否存在.若不存在,则创建一个*/        if (!(new File(newPath)).exists()) {               (new File(newPath)).mkdir();//创建目录        }        /*遍历当前目录下的子目录和文件*///        for (int i = 0; i < filePath.length; i++)        for (String x : filePath) {               /*如果这(x)是一个子目录:(执行递归)*/            if ((new File(oldPath + File.separator + x)).isDirectory()) {                   copyDir(oldPath + File.separator + x, newPath + File.separator + x);            }/*java.io.Filepublic static final String separator //这个separator属性java.io软件包下的File类的一个公开的静态且是常量的属性(成员变量),是方便的智能的分割符.The system-dependent default name-separator character, represented as a string for convenience. This string contains a single character, namely separatorChar.*/            /*如果x所指的是个文件:执行复制即可*/            if (new File(oldPath + File.separator + x).isFile()) {                   File source = new File(oldPath + File.separator + x);                File dest = new File(newPath + File.separator + x);                if (!(dest.exists())) {                       Files.copy(source.toPath(), dest.toPath());//应当创建新文件的能力                }            }        }//endFor        System.out.println("The replication operation has been successfully executed!");    }//endCopyFunction}

说明并修正某些内容,对比

package experiment8.exp1;import java.io.File;import java.io.IOException;import java.nio.file.Files;import java.util.Scanner;public class CopyDirectoryAndFiles {       public static void main(String[] args) throws IOException {           Scanner scanner = new Scanner(System.in);        System.out.println("输入被复制源目录名:");        String sourceDirectory = scanner.nextLine();        System.out.println("输入副本目标目录名");        String destinationDirectory = scanner.nextLine();        /*调用递归复制函数.*/        copyDir(sourceDirectory, destinationDirectory);    }    /*本递归复制函数具有检查并创建新目录的能力,*/    static void copyDir(String oldPath, String newPath) throws IOException {           File file = new File(oldPath);        String[] filePath = file.list();/*//当前路径下存在的目录名和文件名的数组.比较建议用list方法,不推荐用listFile方法,因为后面        要通过连接目录名来创建新目录,用字符串比较方便.*/        /*检查新目录是否存在.若不存在,则创建一个(搭配规则1使用的,对参数的尾缀有一致性要求        否则有些细微差异,就是第一层的目录结构要丢失)*/ /*       if (!(new File(newPath)).exists()) {            (new File(newPath)).mkdir();//创建目录        }*/        /*规则2使用;对路径名的尾缀没有要求的*/        if (file.isDirectory()) {               //System.out.println(file.getName());            (new File(newPath + File.separator + file.getName())).mkdir();            newPath = newPath + File.separator + file.getName();        }        /*遍历当前目录下的子目录和文件*///        for (int i = 0; i < filePath.length; i++)        for (String x : filePath) {               /*如果这(x)是一个子目录:(执行递归)*/            if ((new File(oldPath + File.separator + x)).isDirectory()) {                   //此处传入的新旧路径名的后缀都是一样的(x)结尾。                /*所以为了保证统一性,在最初的使用(调用此递归函数时,对参数的形式上就有所约定。                 * 你有两中方向可选。                 * 1、在最初的调用中,就把路径名处理成尾缀一致的。                 * 2.在函数的递归的编写就不要提前处理成尾缀一致的。*/                //这里我们这里尝试一下2。                copyDir(oldPath + File.separator + x, newPath + File.separator);            }            /*如果x所指的是个文件:执行复制即可*/            if (new File(oldPath + File.separator + x).isFile()) {                   File source = new File(oldPath + File.separator + x);                File dest = new File(newPath + File.separator + x);                if (!(dest.exists())) {                       Files.copy(source.toPath(), dest.toPath());//应当创建新文件的能力                }            }        }//endFor        System.out.println("The replication operation has been successfully executed!");    }//endCopyFunction}

转载地址:http://avzt.baihongyu.com/

你可能感兴趣的文章
mysql 快速自增假数据, 新增假数据,mysql自增假数据
查看>>
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
Mysql 拼接多个字段作为查询条件查询方法
查看>>
mysql 排序id_mysql如何按特定id排序
查看>>
Mysql 提示:Communication link failure
查看>>
mysql 插入是否成功_PDO mysql:如何知道插入是否成功
查看>>
Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
查看>>
mysql 数据库备份及ibdata1的瘦身
查看>>
MySQL 数据库备份种类以及常用备份工具汇总
查看>>
mysql 数据库存储引擎怎么选择?快来看看性能测试吧
查看>>
MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
查看>>
MySQL 数据库的高可用性分析
查看>>
MySQL 数据库设计总结
查看>>
Mysql 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>