在java中对文件与文件目录的操作主要集中在java.io包,但是对于文件夹的操作还没有可用的直接处理方法。
对文件的操作最好的办法就是递归,很多人一听递归就放弃了,其实递归是很简单的,我先从递归设计的基本思想入手:
递归算法设计的基本思想是:对于一个复杂的问题,把原问题分解为若干个相对简单类同的子问题,继续下去直到子问题简单到能够直接求解,也就是说到了递推的 出口,这样原问题就有递推得解。
关键要抓住的是:
(1)递归出口
(2)地推逐步向出口逼近
只要把基本思想和关键的抓住,递归运算会和我们写Hello World一样的简单。
文件夹删除操作:
//originalFile源文件夹
public static void referDeleteFile(File originalFile) {
File filelist[] = originalFile.listFiles(); //获得文件夹的集合操作
for (File file : filelist) { //遍历
if (file.isDirectory()) { //判断是否是目录
referDeleteFile(file); //递归
} else {
file.delete(); //当不是目录时删除文件
}
}
originalFile.delete(); // 删除当前目录
}
文件夹拷贝操作:
//originalDir 源路径
//aimDir 目标路径
public static void referCopyFile(String originalDir, String aimDir) {
File originalFile = new File(originalDir); //实例化源文件
File filelist[] = originalFile.listFiles();//获得文件集合
for (File file : filelist) { //遍历
if (file.isDirectory()) {//判断是否是文件夹
new File(aimDir + File.separator + file.getName()).mkdirs();//在目标路径上创建目录
referCopyFile(originalDir + File.separator + file.getName(),//递归
aimDir + File.separator + file.getName());
} else {
if (file.isFile()) { //判断文件是否真实存在
BufferedInputStream bis = null;
FileInputStream in = null;
BufferedOutputStream bos = null;
FileOutputStream out = null;
try {
in = new FileInputStream(file);
bis = new BufferedInputStream(in);
out = new FileOutputStream(new File(aimDir
+ File.separator + file.getName()));
bos = new BufferedOutputStream(out);
byte[] b = new byte[1024 * 10];
int len;
while ((len = bis.read(b)) != -1) {
bos.write(b, 0, len);
}
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
try {
bos.flush();
bos.close();
out.close();
bis.close();
in.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
} else {
System.out.println("目标文件不存在");
}
}
}
}
上面的文件夹拷贝根目录并没有拷贝过去,有需要的朋友可以先创建一下根目录。
在java中对文件夹的拷贝和删除
最新推荐文章于 2024-06-16 22:47:03 发布