Java利用文件輸入輸出流實現(xiàn)文件夾內(nèi)所有文件拷貝到另一個文件夾
一、基本目標
使用Java完成如下的操作:
把一個文件夾內(nèi)的所有文件拷貝的另一的文件夾,例如,在F盤中有a與b兩個文件夾:

f:/a里面有一堆文件,運行Java程序之后就會全部復制到f:/b,并且完成重命名,在所有文件之前加rename_的前綴,如果里面有文件夾,則文件夾不重命名,里面的文件進行重命名,同樣在所有文件之前加rename_的前綴:

二、制作過程
1、首先主函數(shù)非常簡單,就是調用了上面FileTest類中的copyFolder函數(shù)
public class FileCopy {
public static void main(String args[]) {
new FileTest().copyFolder("f:/a", "f:/b");
}
}
值得注意的是,這個的傳遞過去的參數(shù)的路徑寫法,在java中,f:/a是沒有問題的,f:\a也是沒有問題的,但是由于\在字符串表達的時候,必須轉移,所以你必須寫成f:\\a
2、整個程序的關鍵在這個FileTest類中的copyFolder函數(shù),這個類里面就這個函數(shù)-_-!而且注意在程序開頭引入java.io.*;由于用到了輸入輸出流
class FileTest {
public void copyFolder(String oldPath, String newPath) {
try {
// 如果文件夾不存在,則建立新文件夾
(new File(newPath)).mkdirs();
//讀取整個文件夾的內(nèi)容到file字符串數(shù)組,下面設置一個游標i,不停地向下移開始讀這個數(shù)組
File filelist = new File(oldPath);
String[] file = filelist.list();
//要注意,這個temp僅僅是一個臨時文件指針
//整個程序并沒有創(chuàng)建臨時文件
File temp = null;
for (int i = 0; i < file.length; i++) {
//如果oldPath以路徑分隔符/或者\結尾,那么則oldPath/文件名就可以了
//否則要自己oldPath后面補個路徑分隔符再加文件名
//誰知道你傳遞過來的參數(shù)是f:/a還是f:/a/啊?
if (oldPath.endsWith(File.separator)) {
temp = new File(oldPath + file[i]);
} else {
temp = new File(oldPath + File.separator + file[i]);
}
//如果游標遇到文件
if (temp.isFile()) {
FileInputStream input = new FileInputStream(temp);
FileOutputStream output = new FileOutputStream(newPath
+ "/" + "rename_" + (temp.getName()).toString());
byte[] bufferarray = new byte[1024 * 64];
int prereadlength;
while ((prereadlength = input.read(bufferarray)) != -1) {
output.write(bufferarray, 0, prereadlength);
}
output.flush();
output.close();
input.close();
}
//如果游標遇到文件夾
if (temp.isDirectory()) {
copyFolder(oldPath + "/" + file[i], newPath + "/" + file[i]);
}
}
} catch (Exception e) {
System.out.println("復制整個文件夾內(nèi)容操作出錯");
}
}
}
可能游標遇到文件部分有點難以理解,其實是這樣的,首先設置一個文件的輸入流,指定從游標遇到的文件中輸入,再指定輸出到newPath/rename_舊文件的文件名這個文件目錄,之后,設置一個緩沖數(shù)組,文件輸入流對于自己要讀取的文件,每次調用read方法,它都會向后繼續(xù)上一次讀取的位置繼續(xù)讀取緩沖數(shù)組bufferarray的長度的內(nèi)容,把讀取到的內(nèi)容存儲到緩沖數(shù)組,覆蓋緩沖數(shù)組之前的所有內(nèi)容,然后文件輸出流會把緩沖數(shù)組的所有內(nèi)容輸出的指定的位置,直到文件輸入流遇到了-1。
至于文件輸入流為何能這樣按順序,每次都會向后繼續(xù)上一次讀取的位置繼續(xù)讀取,那是因為當要進行文件的讀取,Java封裝的FileInputStream.read方法也會調用操作系統(tǒng)的API依次讀取這些數(shù)據(jù)。在讀取文件數(shù)據(jù)的時候必須是順序的,不可能說先讀取第一個字節(jié),后讀取倒數(shù)第二個字節(jié)。循環(huán)讀取的時候就read方法將讀取的位置++,因此造成每次read都是順序讀取后面的字節(jié),直到遇到文件末尾標記。
當游標遇到文件夾則重新調用自己完成同樣的操作即可,這就是所謂的迭代。
3、因此整個程序如下:
import java.io.*;
/**
*
* @param oldPath 被拷貝的目錄
* @param newPath 要拷貝到的目錄
*
*/
class FileTest {
public void copyFolder(String oldPath, String newPath) {
try {
// 如果文件夾不存在,則建立新文件夾
(new File(newPath)).mkdirs();
//讀取整個文件夾的內(nèi)容到file字符串數(shù)組,下面設置一個游標i,不停地向下移開始讀這個數(shù)組
File filelist = new File(oldPath);
String[] file = filelist.list();
//要注意,這個temp僅僅是一個臨時文件指針
//整個程序并沒有創(chuàng)建臨時文件
File temp = null;
for (int i = 0; i < file.length; i++) {
//如果oldPath以路徑分隔符/或者\結尾,那么則oldPath/文件名就可以了
//否則要自己oldPath后面補個路徑分隔符再加文件名
//誰知道你傳遞過來的參數(shù)是f:/a還是f:/a/???
if (oldPath.endsWith(File.separator)) {
temp = new File(oldPath + file[i]);
} else {
temp = new File(oldPath + File.separator + file[i]);
}
//如果游標遇到文件
if (temp.isFile()) {
FileInputStream input = new FileInputStream(temp);
FileOutputStream output = new FileOutputStream(newPath
+ "/" + "rename_" + (temp.getName()).toString());
byte[] bufferarray = new byte[1024 * 64];
int prereadlength;
while ((prereadlength = input.read(bufferarray)) != -1) {
output.write(bufferarray, 0, prereadlength);
}
output.flush();
output.close();
input.close();
}
//如果游標遇到文件夾
if (temp.isDirectory()) {
copyFolder(oldPath + "/" + file[i], newPath + "/" + file[i]);
}
}
} catch (Exception e) {
System.out.println("復制整個文件夾內(nèi)容操作出錯");
}
}
}
public class FileCopy {
public static void main(String args[]) {
new FileTest().copyFolder("f:/a", "f:/b");
}
}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Springboot如何通過filter修改Header的值
這篇文章主要介紹了Springboot如何通過filter修改Header的值問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07
Tomcat?8.5?+mysql?5.7+jdk1.8開發(fā)JavaSE的金牌榜小項目
這篇文章主要介紹了Tomcat?8.5?+mysql?5.7+jdk1.8開發(fā)JavaSE的金牌榜小項目,本文通過圖文實例相結合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05
Java+opencv3.2.0實現(xiàn)hough直線檢測
這篇文章主要為大家詳細介紹了Java+opencv3.2.0之hough直線檢測,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-02-02

