python 實現文件的遞歸拷貝


今天翻電腦時突然發現有個存了很多照片和視頻的文件夾,想起來是去年換手機(流行的小5)時拷出來的。看了幾張

照片,往事又一幕幕的浮現在腦海,好吧,我是個感性的人。所以就想把這些照片翻着看一遍,可是拷出來的照片手機

里是按時間自動分文件夾的,一個一個文件夾拷很是麻煩,於是打算寫個python小腳本來完成這個工作(扯這么多,終於

到主題了,囧)

 

這是待拷貝的文件夾根目錄,每個子目錄下都有若干照片。

廢話少說,上代碼:

 

# -*- coding: utf-8 -*- #!/usr/bin/python #Filename:copyfile.py
import os,shutil def mycopy(srcpath,dstpath): if not os.path.exists(srcpath): print "srcpath not exist!"
    if not os.path.exists(dstpath): print "dstpath not exist!"
    for root,dirs,files in os.walk(srcpath,True): for eachfile in files: shutil.copy(os.path.join(root,eachfile),dstpath) srcpath='e:\\pic' dstpath='f:\\pictotal' mycopy(srcpath,dstpath)

 

運行這個腳本,去f盤看看:

照片都拷貝了過來,果然有很多照片(底下還有很多,沒截完)

代碼沒有什么難懂的,主要是os.walk()函數,這個函數返回指定路徑的三元組(起始路徑,起始路徑下的目錄,起始路徑下不帶路徑名的文件名列表)

它直接可以遞歸遍歷到指定目錄下的所有目錄及文件名,比較好用。

也可以用os.listdir(dirname):函數來實現,listdir函數列出dirname下的目錄和文件,然后通過一個判斷:若是文件,則拷貝;若是目錄,則繼續遞歸

遍歷,顯然沒有walk()函數用起來方便。不過不知道walk()函數內部是怎么實現的,若是直接將根目錄下的所有文件存在list中性能上可能不太好,

后面可以用listdir()對比測一下。

 

可以看出,python僅需短短幾行的代碼就完成了這個工作,還是很方便的。若用C++來實現代碼就比這個長了。

可見,語言無所謂高低,能高效方便實現目標就好,不是嗎?


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM