使用Python编写批量文件重命名工具

 更新时间:2025年05月21日 09:14:40   作者:小羊客栈  
有时候呢,你的文件被下载下来文件名都是乱七八糟毫无规律,但是当时你下载的时候没办法重名或者你又不想另存为重新重命名,所以我们就来使用Python编写一个文件批量重命名工具吧

一、前言

今天来分享一款好玩的自动化脚:批量文件重命名有时候呢,你的文件被下载下来文件名都是乱七八糟毫无规律,但是当时你下载的时候没办法重名或者你又不想另存为重新重命名。

比如:下载下来的照片每一个文件名字系统给你安排的都是系统自身的喜好

所以它来了,一次性完成。

二、效果

三、源码

import os
import tkinter as tk
from tkinter import ttk, filedialog, messagebox
from pathlib import Path


class BatchRenameApp:
    def __init__(self, root):
        self.root = root
        self.root.title(" 批量文件重命名工具 v1.0")
        self.root.geometry("800x600")

        # 变量初始化
        self.folder_path = tk.StringVar()
        self.prefix = tk.StringVar(value="")
        self.suffix = tk.StringVar(value="")
        self.start_num = tk.IntVar(value=1)
        self.ext_filter = tk.StringVar(value="*")
        self.dry_run = tk.BooleanVar(value=False)
        self.file_list = []

        # 创建UI组件
        self.create_widgets()

    def create_widgets(self):
        # 顶部框架 - 文件夹选择和基本信息
        top_frame = ttk.LabelFrame(self.root, text="文件夹设置", padding=(10, 5))
        top_frame.pack(fill=tk.X, padx=10, pady=5)

        ttk.Label(top_frame, text="目标文件夹:").grid(row=0, column=0, sticky=tk.W)
        ttk.Entry(top_frame, textvariable=self.folder_path, width=50).grid(row=0, column=1, padx=5)
        ttk.Button(top_frame, text="浏览...", command=self.browse_folder).grid(row=0, column=2)

        # 中间框架 - 重命名规则设置
        middle_frame = ttk.LabelFrame(self.root, text="重命名规则", padding=(10, 5))
        middle_frame.pack(fill=tk.X, padx=10, pady=5)

        ttk.Label(middle_frame, text="文件名前缀:").grid(row=0, column=0, sticky=tk.W)
        ttk.Entry(middle_frame, textvariable=self.prefix).grid(row=0, column=1, padx=5, pady=5, sticky=tk.W)

        ttk.Label(middle_frame, text="文件名后缀:").grid(row=1, column=0, sticky=tk.W)
        ttk.Entry(middle_frame, textvariable=self.suffix).grid(row=1, column=1, padx=5, pady=5, sticky=tk.W)

        ttk.Label(middle_frame, text="起始编号:").grid(row=2, column=0, sticky=tk.W)
        ttk.Spinbox(middle_frame, textvariable=self.start_num, from_=1, to=9999).grid(row=2, column=1, padx=5, pady=5,
                                                                                      sticky=tk.W)

        ttk.Label(middle_frame, text="文件类型:").grid(row=3, column=0, sticky=tk.W)
        ttk.Entry(middle_frame, textvariable=self.ext_filter).grid(row=3, column=1, padx=5, pady=5, sticky=tk.W)

        ttk.Checkbutton(middle_frame, text="仅预览(不实际修改)", variable=self.dry_run).grid(row=4, column=0,
                                                                                             columnspan=2, pady=5)

        # 底部框架 - 操作按钮和文件列表
        bottom_frame = ttk.Frame(self.root)
        bottom_frame.pack(fill=tk.BOTH, expand=True, padx=10, pady=5)

        button_frame = ttk.Frame(bottom_frame)
        button_frame.pack(fill=tk.X, pady=5)

        ttk.Button(button_frame, text="扫描文件", command=self.scan_files).pack(side=tk.LEFT, padx=5)
        ttk.Button(button_frame, text="预览重命名", command=self.preview_rename).pack(side=tk.LEFT, padx=5)
        ttk.Button(button_frame, text="执行重命名", command=self.execute_rename).pack(side=tk.LEFT, padx=5)

        # 文件列表树状视图
        self.tree = ttk.Treeview(bottom_frame, columns=("new_name", "status"), show="headings")
        self.tree.heading("#0", text="原始文件名")
        self.tree.heading("new_name", text="新文件名")
        self.tree.heading("status", text="状态")

        vsb = ttk.Scrollbar(bottom_frame, orient="vertical", command=self.tree.yview)
        hsb = ttk.Scrollbar(bottom_frame, orient="horizontal", command=self.tree.xview)
        self.tree.configure(yscrollcommand=vsb.set, xscrollcommand=hsb.set)

        self.tree.pack(side=tk.LEFT, fill=tk.BOTH, expand=True)
        vsb.pack(side=tk.RIGHT, fill=tk.Y)
        hsb.pack(side=tk.BOTTOM, fill=tk.X)

    def browse_folder(self):
        folder_selected = filedialog.askdirectory()
        if folder_selected:
            self.folder_path.set(folder_selected)
            self.scan_files()

    def scan_files(self):
        folder = Path(self.folder_path.get())
        if not folder.exists():
            messagebox.showerror(" 错误", "文件夹不存在!")
            return

        ext = self.ext_filter.get().strip()
        pattern = f"*.{ext}" if ext != "*" else "*"

        try:
            self.file_list = sorted([f for f in folder.glob(pattern) if f.is_file() and not f.name.startswith('.')])
            self.update_file_list()
            messagebox.showinfo(" 完成", f"找到 {len(self.file_list)}  个文件")
        except Exception as e:
            messagebox.showerror(" 错误", f"扫描文件时出错: {str(e)}")

    def update_file_list(self):
        self.tree.delete(*self.tree.get_children())
        for i, file in enumerate(self.file_list, start=self.start_num.get()):
            new_name = f"{self.prefix.get()}{i}{self.suffix.get()}{file.suffix}"
            self.tree.insert("", tk.END, text=file.name, values=(new_name, "待处理"))

    def preview_rename(self):
        if not self.file_list:
            messagebox.showwarning(" 警告", "请先扫描文件!")
            return

        self.dry_run.set(True)
        self.update_file_list()
        messagebox.showinfo(" 预览", "已生成重命名预览,请查看文件列表")

    def execute_rename(self):
        if not self.file_list:
            messagebox.showwarning(" 警告", "请先扫描文件!")
            return

        if self.dry_run.get():
            messagebox.showinfo(" 信息", "当前处于预览模式,不会实际修改文件")
            return

        if not messagebox.askyesno(" 确认", f"确定要重命名 {len(self.file_list)}  个文件吗?"):
            return

        success_count = 0
        for i, file in enumerate(self.file_list, start=self.start_num.get()):
            new_name = f"{self.prefix.get()}{i}{self.suffix.get()}{file.suffix}"
            new_path = file.with_name(new_name)

            try:
                file.rename(new_path)
                self.tree.item(self.tree.get_children()[i - self.start_num.get()],
                               values=(new_name, "成功"))
                success_count += 1
            except Exception as e:
                self.tree.item(self.tree.get_children()[i - self.start_num.get()],
                               values=(new_name, f"失败: {str(e)}"))

        messagebox.showinfo(" 完成", f"操作完成!\n成功: {success_count}\n失败: {len(self.file_list) - success_count}")
        self.file_list = []  # 清空文件列表,防止重复操作


if __name__ == "__main__":
    root = tk.Tk()
    app = BatchRenameApp(root)
    root.mainloop()

到此这篇关于使用Python编写批量文件重命名工具的文章就介绍到这了,更多相关Python文件重命名内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • django 删除数据库表后重新同步的方法

    django 删除数据库表后重新同步的方法

    今天小编就为大家分享一篇django 删除数据库表后重新同步的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05
  • Python实现自动批量修改文件名称

    Python实现自动批量修改文件名称

    这篇文章主要为大家详细介绍了如何基于Python语言,实现按照一定命名规则批量修改多个文件的文件名的效果,文中的示例代讲解详细,感兴趣的可以了解一下
    2023-01-01
  • 详解pandas中Series()和DataFrame()的区别与联系

    详解pandas中Series()和DataFrame()的区别与联系

    本文主要介绍了详解pandas中Series()和DataFrame()的区别与联系,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • Python实现随机生成算术题的示例代码

    Python实现随机生成算术题的示例代码

    这篇文章主要为大家详细介绍了如何利用Python实现随机生成算术题的功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-04-04
  •  Python错误与异常处理

     Python错误与异常处理

    这篇文章主要介绍了 Python错误与异常处理,错误与异常处理在Python中具有非常重要的地位,熟练的使用错误与异常处理能够为我们的Python编程提供很多的便利之处,希望您阅读完本文后能够有所收获
    2022-01-01
  • Pytorch中index_select() 函数的实现理解

    Pytorch中index_select() 函数的实现理解

    这篇文章主要介绍了Pytorch中index_select() 函数的实现理解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • Go1.16引入目录遍历优化解析

    Go1.16引入目录遍历优化解析

    Go1.16版本中,对目录遍历进行了显著的优化,新增的接口os.ReadDir、(*os.File).ReadDir和filepath.WalkDir使用fs.DirEntry代替os.FileInfo,减少了系统调用次数,提高了遍历效率,测试显示,优化后的遍历速度比原先快了480%
    2024-10-10
  • python基础之并发编程(一)

    python基础之并发编程(一)

    这篇文章主要介绍了详解python的并发编程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-10-10
  • python小程序基于Jupyter实现天气查询的方法

    python小程序基于Jupyter实现天气查询的方法

    这篇文章主要介绍了python小程序基于Jupyter实现天气查询的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • python使用django调用deepseek api搭建ai网站

    python使用django调用deepseek api搭建ai网站

    DeepSeek是一家人工智能公司,致力于通过创新的技术和算法,推动人工智能领域的发展,本文给大家介绍了python使用django调用deepseek api搭建ai网站,文中有相关的代码示例供大家参考,感兴趣的小伙伴跟着小编一起来看看吧
    2025-02-02

最新评论