一行 Python 實現文件批量重命名的七種方法
今天我們要解鎖一個超級實用的Python小技巧——如何用一行代碼實現文件的批量重命名!別看這操作簡單,它可是能大大提升你的工作效率,讓你在文件管理上顯得格外“機智”哦!
首先,確保你的電腦上已經安裝了Python,然后我們開始這場魔法之旅吧!
方法1: 簡單替換法
假設我們要把所有“old_name”開頭的文件改為“new_name”,看這行代碼的魔力!
import os; [os.rename(f, f.replace('old_name', 'new_name')) for f in os.listdir('.') if f.startswith('old_name')]
解讀時間 : 這行代碼首先導入了os模塊,然后用列表推導式遍歷當前目錄下的所有文件(.listdir('.')),檢查文件名是否以“old_name”開始(if f.startswith('old_name')),如果是,就使用replace方法替換掉“old_name”為“new_name”。簡單粗暴,一氣呵成!
方法2: 序列號賦予師
如果你想要給文件加上連續的數字,比如“file_1”,“file_2”...
import os, itertools; [os.rename(f, f'file_{i}') for i, f in enumerate(os.listdir('.'), start=1)]
解密中 : enumerate函數是個好幫手,它給每個文件名配了個序號,從1開始(start=1),然后我們用這個序號和文件名結合,生成新的文件名。是不是很有條理?
方法3: 時間戳變形記
給文件加上時間戳,讓重命名帶有時間信息,非常適合日志文件管理。
import os, datetime; [os.rename(f, f"{datetime.datetime.now().strftime('%Y%m%d_%H%M%S')}_{f}") for f in os.listdir('.')]
魔法解析 : 使用datetime.now().strftime('%Y%m%d_%H%M%S')生成當前日期時間的字符串,然后拼接到原文件名前,這樣每個文件都穿上了一件時間編碼的外衣。
方法4: 擴展名專精者
有時候我們只想改動文件名,保留擴展名,這招搞定!
import os; [os.rename(f, f.stem+'_modified'+f.suffix) for f in os.scandir('.') if f.is_file()]
技術揭秘 : f.stem獲取文件名不包括擴展名的部分,f.suffix則是擴展名,這行代碼就是在文件名后加了個"_modified"。
方法5: 模式匹配大師
正則表達式的舞臺,靈活匹配并重命名。
import os, re; [os.rename(f, re.sub(r'pattern', 'replacement', f)) for f in os.listdir('.') if re.match(r'pattern', f)]
高手進階 : 這里r'pattern'是你想匹配的模式,'replacement'是替換后的文本。比如,如果你想把所有包含“example”的文件名中的“example”換成“sample”,只需調整這兩個參數即可。
方法6: 數字排序狂人
如果你的文件名是亂序的數字,比如“file1”,“file10”,想按數字排序重命名,這招超有用!
import os; files = sorted(os.listdir('.'), key=lambda x: int(x.split('.')[0]))
for i, f in enumerate(files, start=1): os.rename(f, f'file{i}')
排序秘籍 : 先用sorted和lambda函數按文件名中的數字排序,然后重新命名,保證了按數字順序排列。
方法7: 高級模板巫師
使用str.format或f-string(Python 3.6+)來創建更復雜的命名規則。
import os; [os.rename(f, f'File-{i:03d}_{f}') for i, f in enumerate(sorted(os.listdir()), start=1)]
魔法公式 : 這里展示了如何使用f-string和格式化來創建帶有前綴“File-”,后面跟著三位數字編號和原文件名的格式。{i:03d}確保編號始終是三位,不足的前面補零。
怎么樣,是不是覺得Python在文件管理上也變得異常有趣?
進一步拓展
擴展討論:安全與異常處理
在批量重命名時,有幾個關鍵點需要注意,以確保操作的安全性和穩定性:
1. 避免重名沖突
在進行重命名時,要確保新名字不會導致同名文件沖突,否則會覆蓋原有文件,造成數據丟失。可以通過先檢查目標文件名是否存在來避免這種情況。
2. 異常處理
在代碼中加入異常處理邏輯,可以讓你的腳本更加健壯。例如,當文件正在被使用,或沒有讀寫權限時,可能會拋出異常。
import os
try:
for i, f in enumerate(sorted(os.listdir()), start=1):
new_name = f'File-{i:03d}_{f}'
if new_name != f: # 避免不必要的重命名
os.rename(f, new_name)
except OSError as e:
print(f"Error: {e.strerror}")
3. 備份策略
在執行大規模重命名之前,尤其是對重要文件進行操作時,創建備份是一個好習慣。這樣即使出了錯,也有恢復的余地。
4. 批量重命名工具函數
為了重復利用這些邏輯,可以將重命名的邏輯封裝成一個函數,便于在不同場景下調用。
def rename_files(pattern, replacement, directory='.'):
import os, re
for filename in os.listdir(directory):
if re.search(pattern, filename):
new_filename = re.sub(pattern, replacement, filename)
os.rename(os.path.join(directory, filename), os.path.join(directory, new_filename))
print("Renaming completed.")
# 示例調用
rename_files(r'old_pattern', 'new_pattern')
實踐建議
- 測試環境:先在測試文件夾中嘗試你的腳本,確保一切如預期。
- 版本控制:對于重要的文件操作,考慮使用版本控制系統(如Git)來追蹤更改。
- 交互式腳本:開發一個簡單的命令行界面,讓用戶確認重命名操作,可以增加靈活性和安全性。
通過這些擴展討論,你不僅學會了如何用一行代碼實現文件批量重命名,還了解了如何使你的代碼更加健壯和實用。希望這些知識能幫助你在未來的編程旅程中更加游刃有余!