
來源:早起Python
作者:陳熹、劉早起
大家好,又到了Python辦公自動化(偷懶)專題。
今天介紹的案例是如何利用Python來自動化移動、修改、重命名文件/夾,這樣的操作在日常辦公中經常會用到,若能掌握用Python實現將會大大提高效率!
所以我希望能夠通過這篇文章來讓大家了解:如何基于 os glob 和 shutil 對文件管理的綜合運用!
為了讓本文介紹的案例更有通用型,我新建了一個文件夾 files1 存放著 1800+ 個文件,如下所示:
需要完成的內容如下
“
將 1835 個文件移動到新文件夾 file2,并且重命名文件,名字開頭加上 序號 和 “終稿” 兩個字,如名字更改為 “1-終稿-xxxxx(原文件名)”
”
你心里可能想著:這是人做的事??? 但確實這是真實的需求,文件批量重命名非常常見,如果沒有一些技巧,那么只能耗費大量的時間和人力去做。這里的技巧,就是 Python
另外還有一個問題:要先移動再重命名還是先重命名再移動呢? 繼續往下看!
真實的辦公場景并不會這樣的需求,畢竟誰想要無端給自己的電腦產生大量無用文件呢(也不要給別人的電腦亂用)
不得不提,生成隨機文件能夠幫助我們更好的測試自己 Python 文件管理的技能。如果你沒有合適的文件夾和文件夾供自己練習,那么為什么不自己寫個代碼產生呢?
當然,在這個過程中我們也會學習一些知識點,先看代碼:
import random import string for i in range(2000):
random_str = ''.join(random.sample(string.ascii_letters + string.digits, random.randint(1, 11)))
file = open(r"C:\xxx\file1" + random_str + ".txt", 'w+') # 前面路徑是產生文件的目標文件夾
file.write(''.join(random.sample(string.ascii_letters + string.digits, random.randint(1, 11))))
file.close()
通過 string 就可以獲得所有的字母和數字,利用 random.sample() 常規接受兩個參數,一個是抽樣的范圍,一個是抽樣的次數,默認是放回抽樣。這樣就可以在給定的字母數字范圍內隨機抽取 1-10 個,但是返回的結果注意是列表,需要再用 .join 方法完成字符串拼接
用隨機產生的名字生成文件后,再在其內部用類似的方法隨機寫入一些內容:
上面的寫法不夠優雅,因為需要配套使用 file.close() 釋放,更好的方法是直接利用上下文管理器 with 結構,減少出錯的幾率
import random import string for i in range(2000):
random_str = ''.join(random.sample(string.ascii_letters + string.digits, random.randint(1, 11)))
with open(r"C:\xxx\file1" + random_str + ".txt", 'w+') as file:
file.write(''.join(random.sample(string.ascii_letters + string.digits, random.randint(1, 11))))
因為即使是隨機產生名字,但抽樣的范圍和次數不大決定了 2000 次抽樣會有一些抽簽組合成的名字完全一樣,后面形成的文件會覆蓋之前產生的文件,最終導致產生的文件沒有 2000 個。
需要用到內置庫 os 的 os.rename() 方法
import os os.rename('practice.txt', 'practice_rename.txt') # 重命名文件 os.rename('文件夾1', '文件夾2') # 重命名文件夾
雖然需求中有重命名文件的需求,但實際上并不需要直接借助這個方法
需要用到內置庫 shutil 的 shutil.move 方法
import shutil
shutil.move(r'.practice.txt', r'.文件夾1/')
shutil.move(r'.practice.txt', r'.文件夾1/new.txt')
注意到上面后兩行代碼的區別嗎?前一行是將目標文件移動到目標文件夾里,而后一行,在將目標文件移動到目標文件夾里的同時,能夠對其進行重命名
也就是說,我們并不需要用 os.rename 先命名文件再用 shutil.move 將其移動的指定文件夾,而是可以用 shutil.move 一步到位。
采用基于 glob 庫的迭代框架:
import glob
path = xxx for file in glob.glob(f'{path}/**/*.xlsx', recursive=True):
pass
上面的代碼能夠獲取給定路徑內部所有文件夾下的 Excel 文件(.xlsx 格式), recursive 參數默認為 False,當為 True 時允許逐級遍歷
而本例需要獲取給定文件夾下的所有 .txt 文件,則更加簡單:
import glob
path = xxx for file in glob.glob(f'{path}/*.txt'):
pass
在上面一節我們已經把需求拆分為多個小塊并理清了思路,現在可以開始寫代碼了。首先導入需要的庫
import os import shutil import glob
path = r"C:xxx" # 存放大量需更名移動文件的文件夾路徑的上一級路徑
上文提到,不需要利用 os.rename 那為什么要導入 os 庫呢?
一方面因為要通過這個庫產生新的文件夾。也可以手動完成,但交給代碼多了判斷也不容易出錯:
if not os.path.exists(path + r'file2'):
os.mkdir(path + r'file2')
另一方面下文還會用它獲取文件名,然后就可以移動更名一步到位,glob 迭代文件框架遍歷獲取文件絕對路徑:
count = 1 # 生成序號 for file in glob.glob(f'{path}\測試\*.txt'):
# 這里是文件絕對路徑,可以用字符串方法直接替換修改,但為了方便理解我還是用路徑拼接 filename = os.path.basename(file)
shutil.move(file, path + r'file2' + f'{count}-終稿-{filename}')
count += 1
看到沒,Python、3秒、搞定、干飯!
數據分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
CDA數據分析師證書考試體系(更新于2025年05月22日)
2025-05-26解碼數據基因:從數字敏感度到邏輯思維 每當看到超市貨架上商品的排列變化,你是否會聯想到背后的銷售數據波動?三年前在零售行 ...
2025-05-23在本文中,我們將探討 AI 為何能夠加速數據分析、如何在每個步驟中實現數據分析自動化以及使用哪些工具。 數據分析中的AI是什么 ...
2025-05-20當數據遇見人生:我的第一個分析項目 記得三年前接手第一個數據分析項目時,我面對Excel里密密麻麻的銷售數據手足無措。那些跳動 ...
2025-05-20在數字化運營的時代,企業每天都在產生海量數據:用戶點擊行為、商品銷售記錄、廣告投放反饋…… 這些數據就像散落的拼圖,而相 ...
2025-05-19在當今數字化營銷時代,小紅書作為國內領先的社交電商平臺,其銷售數據蘊含著巨大的商業價值。通過對小紅書銷售數據的深入分析, ...
2025-05-16Excel作為最常用的數據分析工具,有沒有什么工具可以幫助我們快速地使用excel表格,只要輕松幾步甚至輸入幾項指令就能搞定呢? ...
2025-05-15數據,如同無形的燃料,驅動著現代社會的運轉。從全球互聯網用戶每天產生的2.5億TB數據,到制造業的傳感器、金融交易 ...
2025-05-15大數據是什么_數據分析師培訓 其實,現在的大數據指的并不僅僅是海量數據,更準確而言是對大數據分析的方法。傳統的數 ...
2025-05-14CDA持證人簡介: 萬木,CDA L1持證人,某電商中廠BI工程師 ,5年數據經驗1年BI內訓師,高級數據分析師,擁有豐富的行業經驗。 ...
2025-05-13CDA持證人簡介: 王明月 ,CDA 數據分析師二級持證人,2年數據產品工作經驗,管理學博士在讀。 學習入口:https://edu.cda.cn/g ...
2025-05-12CDA持證人簡介: 楊貞璽 ,CDA一級持證人,鄭州大學情報學碩士研究生,某上市公司數據分析師。 學習入口:https://edu.cda.cn/g ...
2025-05-09CDA持證人簡介 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度、美團、阿里等 ...
2025-05-07相信很多做數據分析的小伙伴,都接到過一些高階的數據分析需求,實現的過程需要用到一些數據獲取,數據清洗轉換,建模方法等,這 ...
2025-05-06以下的文章內容來源于劉靜老師的專欄,如果您想閱讀專欄《10大業務分析模型突破業務瓶頸》,點擊下方鏈接 https://edu.cda.cn/g ...
2025-04-30CDA持證人簡介: 邱立峰 CDA 數據分析師二級持證人,數字化轉型專家,數據治理專家,高級數據分析師,擁有豐富的行業經驗。 ...
2025-04-29CDA持證人簡介: 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度,美團,阿里等 ...
2025-04-28CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-27數據分析在當今信息時代發揮著重要作用。單因素方差分析(One-Way ANOVA)是一種關鍵的統計方法,用于比較三個或更多獨立樣本組 ...
2025-04-25CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-25