Python实现文件批量重命名器

2025-05-26 03:50

本文主要是介绍Python实现文件批量重命名器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Python实现文件批量重命名器》在日常工作和学习中,我们经常需要对大量文件进行重命名操作,本文将介绍一个使用Python开发的文件批量重命名工具,提供了多种重命名模式,有需要的小伙伴可以了解下...

前言

在日常工作和学习中,我们经常需要对大量文件进行重命名操作。手动一个个修改既耗时又容易出错,特别是当文件数量较多时。本文将介绍一个使用python开发的文件批量重命名工具,它提供了多种重命名模式,可以大大提高文件管理效率。

功能特点

多种重命名模式:前缀添加、后缀添加、字符串替换、序列号命名

交互式操作界面:清晰的提示和引导

安全机制:操作前确认、冲突检测、错误处理

灵活配置:可自定义序列号格式、起始值和分隔符

模块化设计

本工具采用模块化设计,将不同功能拆分为独立函数,提高代码可读性和可维护性。下面我们来逐一了解各个模块的实现。

1.目录路径获取模块

import os


def get_directory():
    """获取用户输入的有效目录路径"""
    while True:
        dir_path = input("请输入要处理的目录路径:").strip()
        if os.path.isdir(dir_path):
            return os.path.normpath(dir_path)
        print(" 目录不存在,请重新输入")

2.文件列表获取模块

import os

def list_files(dir_path)android:
    """列出目录中的所有文件并返回列表"""
    files = [f for f in sorted(os.listdir(dir_path))
             if os.path.isfile(os.path.join(dir_path, f))]

    print("\n目录文件列表:")
    for idx, f in enumerate(files, 1):
        print(f"{idx:02d}. {f}")
    return files

3.重命名模式选择模块

def get_rename_mode():
    """获取用户选择的命名模式"""
    print("\n请选择重命名模式:")
    print("1. 添加前缀\t2. 添加后缀")
    print("3. 替换字符串\t4. 序列号")
    while True:
        mode = input("请输入选项 (1-4):").strip()
        if mode in {'1', '2', '3', '4'}:
            return mode
        print(" 无效输入,请重新选择")

4.序列号参数配置模块

def get_sequence_params():
    """获取序列号模式参数"""
    print("\n序列号模式参数设置:")
    try:
        start = int(input("起始数字 (默认1):") or 1)
        digits = int(input("位数 (默认3):") or 3)
        sep = input("分隔符 (默认_):") or "_"
        return start, digits, sep
    except ValueError:
        print("! 输入无效,使用默认设置:起始=1,位数=3,分隔符=_")
        return 1, 3, "_"

完整代码实现

下面是整合了所有模块的完整代码实现:

import os


def get_directory():
    """获取用户输入的有效目录路径"""
    while True:
        dir_path = input("请输入要处理的目录路径:").strip()
        if os.path.isdir(dir_path):
            re编程turn os.path.normpath(dir_path)
        print(" 目录不存在,请重新输入")


def list_files(dir_path):
    """列出目录中的所有文件并返回列表"""
    files = [f for f in sorted(os.listdir(dir_path))
             if os.path.isfile(os.path.join(dir_path, f))]

    print("\n目录文件列表:")
    for idx, f in enumerate(files, 1):
        print(f"{idx:02d}. {f}")
    return files


def get_rename_mode():
    """获取用户选择的命名模式"""
    print("\n请选择重命名模式:")
    print("1. 添加前缀\t2. 添加后缀")
    print("3. 替换字符串\t4. 序列号")
    while True:
        mode = input("请输入选项 (1-4):").strip()
        if mode in {'1', '2', '3', '4'}:
            return mode
        print(" 无效输入,请重新选择")


def get_sequence_params():
    """获取序列号模式参数"""
    print("\n序列号模式参数设置:")
    try:
        start = int(input("起始数字 (默认1):") or 1)
        digits = int(input("位数 (默认3):") or 3)
        sep = input("分隔符 (默认_):") or "_"
        return start, digits, sep
    except ValueError:
        print("! 输入无效,使用默认设置:起始=1,位数=3,分隔符=_")
        return 1, 3, "_"


def main():
    # 获取目录路径
    dir_path = get_directory()

    # 获取文件列表
    files = list_files(dir_path)
    if not files:
        print("! 该目录没有可操作文件")
        return

    # 确认操作
    if input("\n是否继续操作?(y/n) ").lower() != China编程'y':
        print("操作已取消")
        return

    # 获取重命名模式
    mode = get_rename_mode()

    # 获取模式参数
    params = {}
    if mode == '1':
        params['prefix'] = input("\n请输入要添加的前缀:")
    elif mode == '2':
        params['suffix'] = input("\n请输入要添加的后缀:")
    elif mode == '3':
        params['old'] = input("\n请输入要替换的字符串:")
        params['new'] = input("请输入替换后的新字符串:")
    elif mode == '4':
        params['start'], params['digits'], params['sep'] = get_sequence_params()

    # 二次确认
    if input("\n!! 确认执行重命名操作?(y/n) ").lower() != 'y':
        print("操作已取消")
        return

    # 执行重命名
    counter = 0
    current_num = params.get('start', 0)

    for filename in files:
        # 跳过隐藏文件(可选)
        if filename.startswith('.'):
            continue

        # 分割文件名和扩展名
        file_path = os.path.join(dir_path, filename)
        base, ext = os.path.splitext(filename)
   编程     new_base = base

        # 根据模式生成新文件名
        if mode == '1':
            new_base = f"{params['prefix']}{base}"
        elif mode == '2':
            new_base = f"{base}{params['suffix']}"
        elif mode == '3':
            new_base = base.replace(params['old'], params['new'])
        elif mode == '4':
            num_format = f"{current_num:0{params['digits']}}d"
            new_base = f"{num_format}{params['sep']}{base}"
            current_num += 1

        new_name = f"{new_base}{ext}"
        new_path = os.path.join(dir_path, new_name)

        # 跳过未修改的情况
        if new_name == filename:
            continue

        # 执行重命名
        try:
            if not os.path.exists(new_path):
                os.rename(file_path, new_path)
                print(f"√ {filename} → {new_name}")
                counter += 1
            else:
                print(f"! 冲突:{new_name} 已存在")
        except Exception as e:
            print(f" 错误:重命名 {filename} 失败 - {str(e)}")

    print(f"\n操作完成,成功重命名 {counter}/{len(files)} 个文件")


if __name__ == "__main__":
    print("=== 文件批量重命名工具 ===")
    main()

代码解析

核心设计思路

用户体验优先:

  • 清晰的提示信息和错误反馈
  • 操作前确认机制,防止误操作
  • 列表显示处理文件,让用户了解操作对象

安全性考虑:

  • 检测目标文件是否存在,避免覆盖
  • 异常捕获处理,确保程序稳定运行
  • 操作结果明确展示,qHCoqSxFS方便用户核对

功能模块化:

  • 每个功能独立封装为函数
  • 清晰的函数命名和注释
  • 参数传递而非全局变量

技术要点

1.路径处理:

  • 使用os.path.isdir()验证目录有效性
  • 使用os.path.normpath()标准化路径格式
  • 使用os.path.join()构建完整文件路径
  • 使用os.path.splitext()分离文件名和扩展名

2.列表推导式:

  • [f for f in sorted(os.listdir(dir_path)) if os.path.isfile(os.path.join(dir_path, f))]
  • 一行代码实现文件过滤和排序

3.字符串格式化:

  • f-string实现动态字符串拼接
  • 使用{current_num:0{params['digits']}}d实现动态宽度的数字格式化

4.输入验证与默认值:

  • 使用input(...) or default_value提供默认值
  • 使用集合{'1', '2', '3', '4'}高效验证输入选项

进阶改进方向

图形界面:添加GUI界面,提升用户体验

正则表达式支持:增加正则表达式匹配和替换功能

预览功能:在执行前预览重命名结果

撤销功能:添加操作日志和撤销功能

批处理模式:支持从配置文件读取参数,实现无人工干预的批处理

递归处理:支持递归处理子目录中的文件

到此这篇关于Python实现文件批量重命名器的文章就介绍到这了,更多相关Python重命名内容请搜索编程China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于Python实现文件批量重命名器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154779

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法