一、基本目標
使用Java完成如下的操作:
把一個文件夾內的所有文件拷貝的另一的文件夾,例如,在F盤中有a與b兩個文件夾:
f:/a裡面有一堆文件,運行Java程序之後就會全部複製到f:/b,並且完成重命名,在所有文件之前加rename_的前綴,如果裡面有文件夾,則文件夾不重命名,裡面的文件進行重命名,同樣在所有文件之前加rename_的前綴:
二、製作過程
1、首先主函數非常簡單,就是調用了上面FileTest類中的copyFolder函數
public class FileCopy { public static void main(String args[]) { new FileTest().copyFolder("f:/a", "f:/b"); } }值得注意的是,這個的傳遞過去的參數的路徑寫法,在java中,f:/a是沒有問題的,f:/a也是沒有問題的,但是由於/在字符串表達的時候,必須轉移,所以你必須寫成f://a
2、整個程序的關鍵在這個FileTest類中的copyFolder函數,這個類裡面就這個函數-_-!而且注意在程序開頭引入java.io.*;由於用到了輸入輸出流
class FileTest { public void copyFolder(String oldPath, String newPath) { try { // 如果文件夾不存在,則建立新文件夾(new File(newPath)).mkdirs(); //讀取整個文件夾的內容到file字符串數組,下面設置一個游標i,不停地向下移開始讀這個數組File filelist = new File(oldPath); String[] file = filelist.list(); //要注意,這個temp僅僅是一個臨時文件指針//整個程序並沒有創建臨時文件File temp = null; for (int i = 0; i < file.length; i++) { //如果oldPath以路徑分隔符/或者/結尾,那麼則oldPath/文件名就可以了//否則要自己oldPath後面補個路徑分隔符再加文件名//誰知道你傳遞過來的參數是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("複製整個文件夾內容操作出錯"); } } }可能游標遇到文件部分有點難以理解,其實是這樣的,首先設置一個文件的輸入流,指定從游標遇到的文件中輸入,再指定輸出到newPath/rename_舊文件的文件名這個文件目錄,之後,設置一個緩衝數組,文件輸入流對於自己要讀取的文件,每次調用read方法,它都會向後繼續上一次讀取的位置繼續讀取緩衝數組bufferarray的長度的內容,把讀取到的內容存儲到緩衝數組,覆蓋緩衝數組之前的所有內容,然後文件輸出流會把緩衝數組的所有內容輸出的指定的位置,直到文件輸入流遇到了-1。
至於文件輸入流為何能這樣按順序,每次都會向後繼續上一次讀取的位置繼續讀取,那是因為當要進行文件的讀取,Java封裝的FileInputStream.read方法也會調用操作系統的API依次讀取這些數據。在讀取文件數據的時候必須是順序的,不可能說先讀取第一個字節,後讀取倒數第二個字節。循環讀取的時候就read方法將讀取的位置++,因此造成每次read都是順序讀取後面的字節,直到遇到文件末尾標記。
當游標遇到文件夾則重新調用自己完成同樣的操作即可,這就是所謂的迭代。
3、因此整個程序如下:
import java.io.*; /** * * @param oldPath 被拷貝的目錄* @param newPath 要拷貝到的目錄* */ class FileTest { public void copyFolder(String oldPath, String newPath) { try { // 如果文件夾不存在,則建立新文件夾(new File(newPath)).mkdirs(); //讀取整個文件夾的內容到file字符串數組,下面設置一個游標i,不停地向下移開始讀這個數組File filelist = new File(oldPath); String[] file = filelist.list(); //要注意,這個temp僅僅是一個臨時文件指針//整個程序並沒有創建臨時文件File temp = null; for (int i = 0; i < file.length; i++) { //如果oldPath以路徑分隔符/或者/結尾,那麼則oldPath/文件名就可以了//否則要自己oldPath後面補個路徑分隔符再加文件名//誰知道你傳遞過來的參數是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("複製整個文件夾內容操作出錯"); } } } public class FileCopy { public static void main(String args[]) { new FileTest().copyFolder("f:/a", "f:/b"); } }以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。