Python中的shutil模塊詳析
前言
Python的Shutil模塊可以看做是OS模塊的補(bǔ)充,它提供了對文件(夾)復(fù)制,移動(dòng),刪除,壓縮和解壓縮的方法。
下面本文會(huì)對shutil模塊的常用方法進(jìn)行分類介紹。
一、文件復(fù)制
shutil模塊提供了多種文件復(fù)制方法,主要方法如下表:
1. shutil.copy(src, dst)
src為源文件路徑(必須是文件),dst為目標(biāo)文件路徑(文件名可加可不加)
目標(biāo)文件如存在會(huì)覆蓋掉,不存在會(huì)創(chuàng)建新文件,包括路徑
只copy內(nèi)容和權(quán)限,其他文件屬性如時(shí)間沒有copy,注意權(quán)限是copy了
返回值為目標(biāo)文件路徑
代碼示例如下:
shutil.copy('../class.py','./') #復(fù)制文件到當(dāng)前目錄,注意dst為目標(biāo)路徑 './class.py' os.listdir('./') #列出當(dāng)前目錄的文件名信息,class.py已創(chuàng)建 ['test3', 'class.py', 'test2', 'function.py', 'function1.py', 'test1'] shutil.copy('../class.py','./class2.py') #復(fù)制文件并重命名,注意dst為文件名 './class2.py' os.listdir('./') #列出當(dāng)前目錄的文件名信息,class2.py已創(chuàng)建 ['test3', 'class.py', 'test2', 'function.py', 'class2.py', 'function1.py', 'test1']
2. shutil.copyfile(src, dst)
src為源文件路徑(必須是文件),dst為目標(biāo)文件路徑,且必須包含文件名
目標(biāo)路徑不存在會(huì)報(bào)錯(cuò)
返回值為目標(biāo)文件路徑
代碼示例如下:
shutil.copyfile('../class.py','./class2.py') #用copyfile復(fù)制文件 './class2.py' shutil.copyfile('../class.py','./os/class2.py') #目標(biāo)文件的目錄不存在會(huì)報(bào)錯(cuò) Traceback (most recent call last): File "<stdin>", line 1, in <module> File "/usr/lib/python3.6/shutil.py", line 121, in copyfile with open(dst, 'wb') as fdst: FileNotFoundError: [Errno 2] No such file or directory: './os/class2.py' shutil.copyfile('../class.py','./') #dst不是文件而是目錄會(huì)報(bào)錯(cuò) Traceback (most recent call last): File "<stdin>", line 1, in <module> File "/usr/lib/python3.6/shutil.py", line 121, in copyfile with open(dst, 'wb') as fdst: IsADirectoryError: [Errno 21] Is a directory: './'
3. shutil.copy2(src, dst)
- src為源文件路徑,dst為目標(biāo)文件路徑
- 同時(shí)復(fù)制源文件的內(nèi)容和stat信息(包含用戶,組,權(quán)限,時(shí)間信息等)
- 返回值為目標(biāo)文件路徑
shutil.copy2()和shutil.copy()的用法很類似,不同點(diǎn)是shutil.copy2()不僅copy了源文件內(nèi)容,同時(shí)copy了源文件的文件屬性,包括修改/訪問時(shí)間(創(chuàng)建時(shí)間貌似無法復(fù)制),權(quán)限等信息。shutil.copy2()相同于同時(shí)做了shutil.copy()和shutil.copystat(),因此該方法名字這里的copy2可以簡單記憶成2次copy。
下面是代碼舉例:
shutil.copy('../class.py','./class2.py') #用copy來復(fù)制文件 './class2.py' time.ctime(os.stat('../class.py').st_mtime) #返回源文件修改時(shí)間 'Sat Jun 8 17:30:32 2019' time.ctime(os.stat('./class2.py').st_mtime) #返回目標(biāo)文件修改時(shí)間,和源文件不一樣 'Sun Sep 18 10:20:36 2022' shutil.copy2('../class.py','./class3.py') #用copy2來復(fù)制文件 './class3.py' time.ctime(os.stat('./class3.py').st_mtime) #返回目標(biāo)文件修改時(shí)間,和源文件一樣 'Sat Jun 8 17:30:32 2019'
4. shutil.copyfileobj(fsrc, fdst,[length=*])
- fsrc為源文件句柄,fdst為目標(biāo)文件句柄,length為copy內(nèi)容大小
- 源文件和目標(biāo)文件必須是已經(jīng)打開的文件句柄
- 沒有返回值
shutil.copyfileobj()方法可以copy一個(gè)打開的文件到另一個(gè)打開的文件,注意源文件和目標(biāo)文件參數(shù)均是文件句柄對象。
代碼示例如下:
file1=open('hr.py','r') #打開源文件 file2=open('hr1.py','w') #打開目標(biāo)文件 shutil.copyfileobj(file1,file2) #文件復(fù)制,注意沒有返回值
5. shutil.copymode(src, dst)
- src為源文件路徑,dst為目標(biāo)文件路徑,可以是文件或者目錄
- 目標(biāo)文件必須已經(jīng)存在,只復(fù)制權(quán)限信息,不復(fù)制內(nèi)容,時(shí)間,用戶和組等信息
- 返回值為目標(biāo)文件路徑
shutil.copymode()只會(huì)復(fù)制文件權(quán)限(st_mode信息),不會(huì)復(fù)制內(nèi)容和其他屬性。
代碼示例如下:
os.system('chmod 777 ../class.py') #用shell指令將源文件的讀寫屬性改變 0 os.system('ls -l ../class.py') #打印源文件的屬性為-rwxrwxrwx -rwxrwxrwx 1 user user 527 6月 8 2019 ../class.py 0 shutil.copyfile('../class.py','./class4.py') #用copyfile來復(fù)制文件 './class4.py' os.system('ls -l ./class4.py') #打印目標(biāo)文件屬性為-rw-r--r--,和源文件不一樣 -rw-r--r-- 1 user user 527 9月 18 10:40 ./class4.py 0 shutil.copymode('../class.py','./class4.py')#用copymode來復(fù)制文件權(quán)限 os.system('ls -l ./class4.py') #打印目標(biāo)文件屬性為-rwxrwxrwx,和源文件一樣 -rwxrwxrwx 1 user user 527 9月 18 10:40 ./class4.py 0
6. shutil.copystat(src, dst)
- src為源文件路徑,dst為目標(biāo)文件路徑,可以是文件或者目錄
- 目標(biāo)文件必須已經(jīng)存在,只復(fù)制stat信息,包含權(quán)限,時(shí)間,組,用戶等,不復(fù)制內(nèi)容
- 返回值為目標(biāo)文件路徑
shutil.copystat()相比shutil.mode(),同樣也不復(fù)制內(nèi)容,不同的是它除了復(fù)制權(quán)限信息,其他stat信息包括修改時(shí)間等也按同樣復(fù)制。
代碼示例如下:
shutil.copyfile('../class.py','./class5.py') #復(fù)制文件 './class5.py' os.system('ls -l ../class.py') #打印源文件信息 -rwxrwxrwx 1 user user 527 6月 8 2019 ../class.py 0 os.system('ls -l ./class5.py') #打印目標(biāo)文件信息,權(quán)限和時(shí)間和源文件不一樣 -rw-r--r-- 1 user user 527 9月 18 10:48 ./class5.py 0 shutil.copystat('../class.py','./class5.py') #復(fù)制文件stat到目標(biāo)文件 os.system('ls -l ./class5.py') #打印目標(biāo)文件信息,權(quán)限和時(shí)間和源文件一樣 -rwxrwxrwx 1 user user 527 6月 8 2019 ./class5.py 0
7. shutil.copytree(src, dst,ignore=none,copy_function=shutil.copy2)
- src為源路徑,dst為目標(biāo)路徑,目標(biāo)路徑必須不存在
- ignore必須是一個(gè)可調(diào)用對象,shutil.copytree()每次遞歸訪問文件夾時(shí),會(huì)將當(dāng)前目錄和目錄的os.listdir()作為參數(shù)調(diào)用一次ignore,該可調(diào)用對象必須返回一個(gè)相對于當(dāng)前目錄的目錄和文件 名序列(即其第二個(gè)參數(shù)的子集);隨后這些名稱將在拷貝進(jìn)程中被忽略。如ignore=shutil.ignore_patterns('*.py'),代表以.py結(jié)尾的文件或者文件夾都不會(huì)復(fù)制。
- copy_function可以選擇shutil.copy2或者shutil.copy模式進(jìn)行copy,默認(rèn)是shutil.copy2
- 返回值為目標(biāo)文件路徑
shutil.copytree()會(huì)遞歸復(fù)制以src為根起點(diǎn)的整個(gè)目錄樹到名為dst的目錄并返回目標(biāo)目錄,注意src必須是目錄,dst必須不能已存在。如果復(fù)制過程中需要忽略某些文件可以使用ignore參數(shù),注意ignore后面需要接可調(diào)用對象,該對象可以是一個(gè)自定義的函數(shù),函數(shù)的參數(shù)有2個(gè),當(dāng)前目錄,和當(dāng)前目錄的os.listdir(),函數(shù)返回的是需要ignore的文件名。該函數(shù)也可以用shutil自帶的shutil.ignore_patterns('*patterns')。
代碼示例如下:
shutil.copytree('/home/user/Python','/home/user/Python1',ignore=None,copy_function=shutil.copy) '/home/user/Python1' os.listdir('/home/cfzhu/Python1') #列出copy后的文件夾中的文件 ['dictionary.py', 'abnormal.py', 'aa.json', '.file.py.swp', '.print.py.swp', 'hello.py', 'class.py', 'input.py', 'function.py', 'shutil', '.abnormal.py.swo', 'os', 'file.py', 'file2', 'print.py', 'file1', '__pycache__', 'import.py', '.abnormal.py.swp', 'file3', 'hr.py', 'tk.py', 'aa1.json'] shutil.copytree('/home/user/Python','/home/user/Python2',ignore=shutil.ignore_patterns('*.py'),copy_function=shutil.copy2) '/home/user/Python2' os.listdir('/home/user/Python2') #copy后的文件名沒有"*py"結(jié)尾的文件 ['aa.json', '.file.py.swp', '.print.py.swp', 'shutil', '.abnormal.py.swo', 'os', 'file2', 'file1', '__pycache__', '.abnormal.py.swp', 'file3', 'aa1.json']
二、文件移動(dòng)和刪除
1. shutil.move(src,dst)
- src為源文件路徑,dst為目標(biāo)文件路徑,兩者都可以是文件或者目錄
- 返回值為目標(biāo)文件路徑
代碼如下(示例):
shutil.move('hr.py','hr1.py') #移動(dòng)文件 'hr1.py' shutil.move('./shutil','./shutil1') #移動(dòng)文件夾 './shutil1'
2. shutil.rmtree(src)
- src為源文件路徑
- 沒有返回值
shutil模塊中的rmtree()可以遞歸徹底刪除非空文件夾,需要慎重使用
代碼如下:
os.listdir() ['.bashrc', 'Python2', '.cache', 'Python1', 'hr_py'] shutil.rmtree('./Python2/') #遞歸刪除文件夾的所有內(nèi)容 os.listdir() #文件夾已刪除 [.bashrc', '.cache', 'Python1', 'hr_py']
三、文件壓縮和解壓縮
1. shutil.make_archive(base_name,format,dir)
- base_name為源文件路徑
- format為壓縮格式,可以是"zip", "tar", "gztar","bztar", or "xztar"
- dir為壓縮后的文件路徑
- 返回壓縮后文件路徑
shutil.make_archive()可以將文件或者文件夾進(jìn)行壓縮,壓縮格式可選,注意壓縮源文件并不會(huì)刪除源文件。
代碼如下(示例):
os.listdir() ['shutil1', 'hr2.py', 'function.py'] shutil.make_archive('./shutil1','zip','./') #壓縮文件為zip格式 '/home/cfzhu/Python/shutil1.zip'
2. shutil.unpack_archive(filename,extract_dir=None, format=None)
- filename為源文件路徑
- extract_dir為提取后的路徑,默認(rèn)當(dāng)前路徑
- format為壓縮格式,可以是"zip", "tar", "gztar","bztar", or "xztar",不指定默認(rèn)為根據(jù)源文件后綴
- 返回壓縮后文件路徑
shutil.unpack_archive()可以將壓縮文件解壓縮。
代碼如下(示例):
shutil.unpack_archive('./shutil1.zip','./shutil2') #解壓縮 os.listdir() ['shutil1', 'dictionary.py', 'shutil2', 'abnormal.py', 'aa.json', '.file.py.swp', '.print.py.swp', 'shutil1.zip', ]
總結(jié)
以上就是shutil的常見方法的介紹,包含了文件復(fù)制,文件移動(dòng)和刪除以及文件壓縮和解壓縮三大部分。
文中每個(gè)方法都提供了實(shí)例演示,希望能對大家有所幫助。
到此這篇關(guān)于Python中的shutil模塊詳析的文章就介紹到這了,更多相關(guān)Python的shutil模塊內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- python常用模塊(math itertools functools sys shutil)使用講解
- Python shutil模塊實(shí)現(xiàn)文件的裁剪、壓縮與解壓縮的方法
- python中用shutil.move移動(dòng)文件或目錄的方法實(shí)例
- python包合集shutil示例代碼詳解
- Python利用shutil實(shí)現(xiàn)拷貝文件功能
- 詳解Python常用標(biāo)準(zhǔn)庫之os模塊與shutil模塊
- Python使用shutil操作文件、subprocess運(yùn)行子程序
- Python利用shutil模塊實(shí)現(xiàn)文件夾的復(fù)制刪除與裁剪
相關(guān)文章
matplotlib中plt.hist()參數(shù)解釋及應(yīng)用實(shí)例
本文主要介紹了matplotlib中plt.hist()參數(shù)解釋及應(yīng)用實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08利用Python制作動(dòng)態(tài)排名圖的實(shí)現(xiàn)代碼
這篇文章主要介紹了利用Python制作動(dòng)態(tài)排名圖的實(shí)現(xiàn)代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04Python繪制loss曲線和準(zhǔn)確率曲線實(shí)例代碼
pytorch雖然使用起來很方便,但在一點(diǎn)上并沒有tensorflow方便,就是繪制模型訓(xùn)練時(shí)在訓(xùn)練集和驗(yàn)證集上的loss和accuracy曲線(共四條),下面這篇文章主要給大家介紹了關(guān)于Python繪制loss曲線和準(zhǔn)確率曲線的相關(guān)資料,需要的朋友可以參考下2022-08-08150行python代碼實(shí)現(xiàn)貪吃蛇游戲
這篇文章主要為大家詳細(xì)介紹了150行python代碼實(shí)現(xiàn)貪吃蛇游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04python實(shí)現(xiàn)對求解最長回文子串的動(dòng)態(tài)規(guī)劃算法
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)對求解最長回文子串的動(dòng)態(tài)規(guī)劃算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-06-06Python腳本實(shí)現(xiàn)Mysql數(shù)據(jù)遷移
MySQL數(shù)據(jù)庫遷移是指將MySQL數(shù)據(jù)庫中的數(shù)據(jù)和結(jié)構(gòu)遷移到另一個(gè)MySQL實(shí)例,下面小編就來為大家介紹一下如何通過Python腳本實(shí)現(xiàn)Mysql數(shù)據(jù)遷移吧2025-03-03