檔案整理不得不先提一下正則運算式
送上鏈接:
python :re模塊基本用法
很多人學習python,不知道從何學起,
很多人學習python,掌握了基本語法過后,不知道在哪里尋找案例上手,
很多已經做案例的人,卻不知道如何去學習更加高深的知識,
那么針對這三類人,我給大家提供一個好的學習平臺,免費領取視頻教程,電子書籍,以及課程的源代碼!
QQ群:961562169
一.列出檔案夾下的所有檔案
用到的庫os
Python os.path() 模塊 詳解 附算例
os.walk()用法
[ (當前目錄串列),(子目錄串列),(檔案串列)]os.walk(樹狀結構檔案夾名稱)
os.walk()回傳一個由3個tuple型別的元素組成的串列,
索引值為0的表元素是檔案夾名稱,據此可以知道當前在處理的檔案夾是哪一個,
索引值為1的表元素是下一層檔案夾串列,用來了解在此檔案夾中還有幾個下層檔案夾,分別叫什么名字,
索引值為2的元素是本檔案夾內所有的檔案串列,列出此檔案夾中所有的檔案名,
由回傳值的串列資料,組合出所有往下的樹狀目錄結構的內容,
import os
list_all=[]#初始化一個空串列
for root ,dirs,files in os.walk(r'C:\Users\Shineion\Desktop\新建檔案夾'):
for name in files:
file_path=os.path.join(root,name)#包含路徑的檔案
file_name=os.path.split(file_path)[-1]
list_all.append(file_name)
print(list_all)
如果檔案夾里含有子檔案夾,子檔案夾有檔案,程式無影響,一樣可以讀取出所有檔案名,
二.使用正則re修改檔案名
import os
import re
#首先定義規則,如我們需要把所有的圖片名提取出來并修改名字
pattern=re.compile(r'.+\.png')
i=1
for root ,dirs,files in os.walk(r'C:\Users\Shineion\Desktop\新建檔案夾'):
for name in files:
file_path=os.path.join(root,name)#包含路徑的檔案名
matching=pattern.search(file_path)#匹配圖片
if matching:
os.rename(file_path,os.path.split(file_path)[-2]+ '/{}.png'.format(i))
i+=1
print('修改成功')
說明
代碼含義os.path.split(path)把路徑分割成 dirname 和 basename,回傳一個元組os.rename傳入兩個引數,左邊舊檔案名(包含路徑的檔案名),第二個引數包含路徑的新檔案名
os.path.split(file_path)[-2]:[-2]:是獲取圖片路徑(除去名字那部分)
之前寫過另一個版本的檔案重命名
:python 批量修改圖片名(也可以用來批量修改檔案名)
三.批量洗掉和復制檔案
1.批量復制檔案
算例:我們將原始檔案夾下的PDF復制到新的檔案夾:D:\余登武測驗1
首先 D:\余登武測驗1 ,需要手動新建
import os
import re
#首先定義規則,如我們需要把所有的pdf檔案
pattern=re.compile(r'.+\.pdf')
for root ,dirs,files in os.walk(r'C:\Users\Shineion\Desktop\新建檔案夾'):
for name in files:
file_path=os.path.join(root,name)#包含路徑的檔案
print(file_path)
matching=pattern.search(file_path)#匹配pdf
if matching:
command_line='copy %s D:\\余登武測驗1' % file_path.replace('/','\\')
os.system(command_line)
print('復制成功')
os.system(command_line)呼叫cmd來執行復制檔案,
cmd復制檔案命令:
copy 源檔案 目的路徑
復制好的檔案
試過幾次后,發現有時復制會失敗,失敗的檔案名含有字母,全字母可以,
2.批量洗掉檔案
洗掉原始檔案夾下的pdf
指令os.remove(檔案)
import os
import re
#首先定義規則,如我們需要把所有的pdf檔案
pattern=re.compile(r'.+\.pdf')
for root ,dirs,files in os.walk(r'C:\Users\Shineion\Desktop\新建檔案夾'):
for name in files:
file_path=os.path.join(root,name)#包含路徑的檔案
print(file_path)
matching=pattern.search(file_path)#匹配pdf
if matching:
os.remove(file_path)
print('洗掉成功')
查看原始檔案夾,發現pdf檔案已洗掉
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/159493.html
標籤:其他
