今天我们要解锁一个超级实用的Python小技巧——如何用一行代码实现文件的批量重命名!别看这操作简单,它可是能大大提升你的工作效率,让你在文件管理上显得格外“机智”哦!
首先,确保你的电脑上已经安装了Python,然后我们开始这场魔法之旅吧!
假设我们要把所有“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”。简单粗暴,一气呵成!
如果你想要给文件加上连续的数字,比如“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),然后我们用这个序号和文件名结合,生成新的文件名。是不是很有条理?
给文件加上时间戳,让重命名带有时间信息,非常适合日志文件管理。
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')生成当前日期时间的字符串,然后拼接到原文件名前,这样每个文件都穿上了一件时间编码的外衣。
有时候我们只想改动文件名,保留扩展名,这招搞定!
import os; [os.rename(f, f.stem+'_modified'+f.suffix) for f in os.scandir('.') if f.is_file()]
技术揭秘 : f.stem获取文件名不包括扩展名的部分,f.suffix则是扩展名,这行代码就是在文件名后加了个"_modified"。
正则表达式的舞台,灵活匹配并重命名。
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”,只需调整这两个参数即可。
如果你的文件名是乱序的数字,比如“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函数按文件名中的数字排序,然后重新命名,保证了按数字顺序排列。
使用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在文件管理上也变得异常有趣?
在批量重命名时,有几个关键点需要注意,以确保操作的安全性和稳定性:
在进行重命名时,要确保新名字不会导致同名文件冲突,否则会覆盖原有文件,造成数据丢失。可以通过先检查目标文件名是否存在来避免这种情况。
在代码中加入异常处理逻辑,可以让你的脚本更加健壮。例如,当文件正在被使用,或没有读写权限时,可能会抛出异常。
import ostry: 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}")
在执行大规模重命名之前,尤其是对重要文件进行操作时,创建备份是一个好习惯。这样即使出了错,也有恢复的余地。
为了重复利用这些逻辑,可以将重命名的逻辑封装成一个函数,便于在不同场景下调用。
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')
通过这些扩展讨论,你不仅学会了如何用一行代码实现文件批量重命名,还了解了如何使你的代码更加健壮和实用。希望这些知识能帮助你在未来的编程旅程中更加游刃有余!
本文链接:http://www.28at.com/showinfo-26-94842-0.html一行 Python 实现文件批量重命名的七种方法
声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com