如何利用Python批量重命名文件

简介: 本文介绍了如何使用Python和PyCharm对文件进行批量重命名,包括文件名前后互换、按特定字符调整顺序等实用技巧,并提供了完整代码示例。同时推荐了第三方工具Bulk Rename Utility,便于无需编程实现高效重命名。适用于需要处理大量文件命名的场景,提升工作效率。

我们有时候遇到文件名刚好调转,需要重新命名一下。

安装Python和使用PyChram编译器

Python的安装在这里并不想多少,目前网络上的教程都是正确的。
自从用了PyChram的编译器,世界更加美好了。编译环境可以根据每个项目不一样而不同。

下载地址:https://www.jetbrains.com/pycharm/

文件名前后互换

将学生名字放到前面而不是后面。
即:500215-John Doe改为John Doe-500215

import os
path='C:\\Users\\UserName\\Desktop\\intro'
# 文件路径格式需要注意!
# 以下是可以使用的格式
#C:\\Users\\Administrator\\Desktop\\intro\\
#C:/Users/Administrator/Desktop/intro/

#获取该目录下所有文件,存入列表中
fileList=os.listdir(path)
#定义文件前缀和后面部分列表
studentID=[]
studentName=[]

n=0
for i in fileList:
    #设置旧文件名(就是路径+文件名)
    oldname=path+os.sep+fileList[n] #os.sep添加系统分隔符
    #print(fileList[n][7:len(fileList[n])-5])
    studentID.insert(n,fileList[n][0:6])
    studentName.insert(n,fileList[n][7:len(fileList[n])-5])
    #len(fileList[n])-5 代表减去了.xlsx文件后缀名

    #设置新文件名
    newname=path+os.sep+studentName[n] + '-'+ studentID[n] + '.xlsx'
    #用os模块中的rename方法对文件改名
    os.rename(oldname,newname)
    print(oldname,'======>',newname)
    n += 1

特定字符前后对换

如果我想将姓放在前面呢?
因为空格位置每个文件不一样,我们怎么做呢?
可不可以根据数据其中一个特定字符,得到这个字符位于单词的位置?
我们可以从下面例子得到一些灵感。

ls = ["a", "b", "c", "d", "e"]
print(ls.index("c"))

>>>2
## 进阶

ls = ["apple", "banana", "coco", "delta", "echo"]
print(ls[0].index("l"))
>>>3

完整代码

import os
path='C:\\Users\\Xadmin\\Desktop\\intro'
# 文件路径格式需要注意!
# 以下是可以使用的格式
#C:\\Users\\Administrator\\Desktop\\intro\\
#C:/Users/Administrator/Desktop/intro/

#获取该目录下所有文件,存入列表中
fileList=os.listdir(path)
#定义文件前缀和后面部分列表
firstName=[]
lastName=[]
StudentID=[]

n=0
for i in fileList:
    #设置旧文件名(就是路径+文件名)
    oldname=path+os.sep+fileList[n] #os.sep添加系统分隔符
    #print(fileList[n][0:len(fileList[n])-5])
    #print(fileList[n].index(" "))
    #len(fileList[n])-5]
    firstName.insert(n, fileList[n][0:fileList[n].index(" ")])
    lastName.insert(n, fileList[n][fileList[n].index(" ")+1:fileList[n].index("-")])
    StudentID.insert(n, fileList[n][fileList[n].index("-")+1:len(fileList[n])-5])
    # len(fileList[n])-5 代表减去了.xlsx文件后缀名
    #print(lastName[n]+' '+firstName[n] + '-'+ StudentID[n])

    #设置新文件名
    newname=path + os.sep + lastName[n]+' '+firstName[n] + '-'+ StudentID[n] + '.xlsx'
    #用os模块中的rename方法对文件改名
    os.rename(oldname,newname)
    print(oldname,'======>',newname)
    n += 1

使用第三方软件批量重命名

实际上,我们有Bulk Rename Utility可以直接使用,不需要特意下载Python。
https://www.bulkrenameutility.co.uk/

相关文章
|
2月前
|
编译器 Python
如何利用Python批量重命名PDF文件
本文介绍了如何使用Python提取PDF内容并用于文件重命名。通过安装Python环境、PyCharm编译器及Jupyter Notebook,结合tabula库实现PDF数据读取与处理,并提供代码示例与参考文献。
|
3月前
|
编解码 Prometheus Java
当Python同时操作1000个文件时,为什么你的CPU只用了10%?
本文介绍如何构建一个高效的文件处理系统,解决单线程效率低、多线程易崩溃的矛盾。通过异步队列与多线程池结合,实现任务调度优化,提升I/O密集型操作的性能。
68 4
|
3月前
|
人工智能 索引 Python
[oeasy]python094_使用python控制音符列表_midi_文件制作
本文介绍了如何使用Python控制音符列表制作MIDI文件。首先回顾了列表下标索引(正数和负数)的用法,接着通过`mido`库实现MIDI文件生成。以《两只老虎》为例,详细解析了代码逻辑:定义音高映射、构建旋律列表、创建MIDI文件框架,并将音符插入音轨。还探讨了音符时值与八度扩展的实现方法。最终生成的MIDI文件可通过不同平台播放或编辑。总结中提到,此技术可用于随机生成符合调性的旋律,同时引发对列表其他实际应用的思考。
101 5
|
5月前
|
Python
使用Python实现multipart/form-data文件接收的http服务器
至此,使用Python实现一个可以接收 'multipart/form-data' 文件的HTTP服务器的步骤就讲解完毕了。希望通过我的讲解,你可以更好地理解其中的逻辑,另外,你也可以尝试在实际项目中运用这方面的知识。
264 69
|
2月前
|
数据采集 监控 算法
Python文件与目录比较全攻略:从基础操作到性能优化
文件比较的核心在于数据指纹校验,通过逐字节比对生成唯一标识,确保内容一致性。从标准库的os与filecmp到高性能第三方库如pydiffx,再到分布式与量子加密技术的未来趋势,文件比较广泛应用于数据备份、代码审查与系统监控等领域,是保障数据完整性的关键技术手段。
79 0
|
3月前
|
数据采集 存储 API
Python爬虫结合API接口批量获取PDF文件
Python爬虫结合API接口批量获取PDF文件
|
3月前
|
数据采集 运维 BI
Python 文件操作进阶|使用 shutil 实现高效文件复制
在开发和运维中,处理大量文件是常见需求,如备份配置、归档日志或构建部署包。手动复制粘贴已无法满足高效需求!Python 的 `shutil` 模块提供了强大的文件操作功能,支持单文件复制、目录树迁移及自动化任务构建。本文详解 `shutil.copy()` 基础用法与进阶技巧,如批量复制、自动路径检测、时间戳命名备份等,助你实现高效自动化。结合实战案例(如自动备份系统),让你的代码更专业!学习后,欢迎交流心得,一起精进 Python 技能。关注我,获取更多编程技巧与源码分享!
|
5月前
|
Shell 开发者 Docker
Python文件打包:一站式指南
本文深入探讨Python文件打包的各种方法,从基础的zip和tar工具到高级的setuptools、PyInstaller、cx_Freeze等,涵盖Docker镜像、虚拟环境及自包含可执行文件的打包方式。通过示例代码与详细解析,帮助开发者根据项目需求选择合适的打包方案,提升代码分发与部署效率。内容全面,适合各水平读者学习参考。
438 7
|
8月前
|
存储 数据采集 数据处理
如何在Python中高效地读写大型文件?
大家好,我是V哥。上一篇介绍了Python文件读写操作,今天聊聊如何高效处理大型文件。主要方法包括:逐行读取、分块读取、内存映射(mmap)、pandas分块处理CSV、numpy处理二进制文件、itertools迭代处理及linecache逐行读取。这些方法能有效节省内存,提升效率。关注威哥爱编程,学习更多Python技巧。
210 8
|
SQL JSON 关系型数据库
n种方式教你用python读写excel等数据文件
n种方式教你用python读写excel等数据文件
172 1

推荐镜像

更多