自动化:批量文件重命名

自动化:批量文件重命名

1、前言
2、效果图
3、源码

一、前言

今天来分享一款好玩的自动化脚:批量文件重命名
有时候呢,你的文件被下载下来文件名都是乱七八糟毫无规律,但是当时你下载的时候没办法重名或者你又不想另存为重新重命名。
比如:下载下来的照片每一个文件名字系统给你安排的都是系统自身的喜好
在这里插入图片描述

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

二、效果

在这里插入图片描述

三、源码

这里有一个智能家居项目(毕设)可以看看(开源:码、论、PPT)

import os
import tkinter as tk
from tkinter import ttk, filedialog, messagebox
from pathlib import Pathclass BatchRenameApp:def __init__(self, root):self.root = rootself.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(" 错误", "文件夹不存在!")returnext = 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(" 警告", "请先扫描文件!")returnself.dry_run.set(True)self.update_file_list()messagebox.showinfo(" 预览", "已生成重命名预览,请查看文件列表")def execute_rename(self):if not self.file_list:messagebox.showwarning(" 警告", "请先扫描文件!")returnif self.dry_run.get():messagebox.showinfo(" 信息", "当前处于预览模式,不会实际修改文件")returnif not messagebox.askyesno(" 确认", f"确定要重命名 {len(self.file_list)}  个文件吗?"):returnsuccess_count = 0for 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 += 1except 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()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/906059.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VueUse/Core:提升Vue开发效率的实用工具库

文章目录 引言什么是VueUse/Core?为什么选择VueUse/Core?核心功能详解1. 状态管理2. 元素操作3. 实用工具函数4. 浏览器API封装5. 传感器相关 实战示例:构建一个拖拽上传组件性能优化技巧与原生实现对比常见问题解答总结 引言 在现代前端开发…

stm32 ADC单通道转换

stm32c8t6仅有12位分辨率 1、单次转换 非扫描 1、初始化 void Ad_Init() {RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE);//配置ADCCLK时钟分频,ADC的输入时钟不得超过14MHzRCC_ADCCLKConfig(RCC_PCLK2_Div6);G…

2KW压缩机驱动参考设计【SCH篇】

实物展示: ACDC: VAC和VAC-为交流电压检测: 1.C33 C34作为Y电容走线宽度要求: Y电容一般用于L/N到地之间(L-PE 或 N-PE),主要作用是抑制共模干扰。其走线的电流非常小,推荐使用 ≥ 1mm 宽的走…

python05——循环结构

1、while循环 n0 #初始条件 while n<5: #判断print(hello python) #要重复执行的代码print(n) #注意同级代码缩进相同n1 #计数器结果&#xff1a; hello python 0 hello python 1 hello python 2 hello python 3 hello python 4 hello python 5 #求阶乘和 sum0 n1 whil…

LINUX编译、运行、测试lowcoder_CN

参考 二者没有太大差异。 LINUX编译、运行、测试lowcoder-CSDN博客 下载 git clone https://github.com/mousheng/lowcoder_CN 或 git clone https://gitcode.com/gh_mirrors/lo/lowcoder_CNcd lowcoder_CN三个模块 node-service api-service client 每个模块都有自己的…

Python 基础之函数命名

几个问题 使用描述性蛇形命名法&#xff08;snake_case&#xff09;Python函数名应使用什么大小写格式&#xff1f;为什么函数名要具有描述性&#xff1f;方法的命名规范是什么&#xff1f;函数、变量和类的命名有何区别&#xff1f; Python函数的命名有一些不可违背的硬性规…

redis 命令大全整理

http://doc.redisfans.com/ 原网址 Redis 命令分类 Key(键) Key(键)命令 exists/del/keys/type/scanobject/move/dump/migratettl/pttl/persist/expireat/pexpireat/expire/pexpirerename/renamenxsort/randomkey/restoreexists 语法:exists key [key ...] 检查一个或多…

React中useDeferredValue与useTransition终极对比。

文章目录 前言一、核心差异对比二、代码示例对比1. useDeferredValue&#xff1a;延迟搜索结果更新2. useTransition&#xff1a;延迟路由切换 三、应用场景总结四、注意事项五、原理剖析1. 核心机制对比2. 关键差异3. 代码实现原理 总结 前言 在React的并发模式下&#xff0c…

高并发内存池|定长内存池的设计

二、定长内存池的设计 设计一个定长的内存池&#xff0c;这个内存池的定长在于&#xff0c;当剩余空间使用完毕后&#xff0c;总是开辟相同长度的新空间来使用。我们会使用到一个指针来切割划分大空间为小空间。大空间是内存池向系统申请的内存大小&#xff0c;而小空间是程序…

微信小程序 自定义图片分享-绘制数据图片以及信息文字

一 、需求 从数据库中读取头像&#xff0c;姓名电话等信息&#xff0c;当分享给女朋友时&#xff0c;每个信息不一样 二、实现方案 1、先将数据库中需要的头像姓名信息读取出来加载到data 数据项中 data:{firstName:, // 姓名img:, // 头像shareImage:,// 存储临时图片 } 2…

从零开始理解Jetty:轻量级Java服务器的入门指南

目录 一、Jetty是什么&#xff1f;先看一个生活比喻 二、5分钟快速入门&#xff1a;搭建你的第一个Jetty服务 步骤1&#xff1a;Maven依赖配置 步骤2&#xff1a;编写简易Servlet&#xff08;厨房厨师&#xff09; 步骤3&#xff1a;组装服务器&#xff08;餐厅开业准备&am…

深入浅出IIC协议 - 从总线原理到FPGA实战开发 -- 第一篇:I2C总线协议深度解剖

第一篇&#xff1a;I2C总线协议深度解剖 副标题 : 两根线如何征服千亿设备&#xff1f;详解硬件工程师必须掌握的通信奥义 1. 为什么I2C仍是嵌入式经典&#xff1f; 1.1 总线拓扑的哲学 拓扑对比图 SPI需4线N片选 vs I2C仅2线级联 UART点对点 vs I2C多主从架构 成本控制实…

MySQL 索引优化以及慢查询优化

在数据库性能优化中&#xff0c;索引优化和慢查询优化是两个关键环节。合理使用索引可以显著提高查询效率&#xff0c;而识别和优化慢查询则能提升整体数据库性能。本文将详细介绍MySQL索引优化和慢查询优化的方法和最佳实践。 一、MySQL 索引优化 1.1 索引的基本概念 索引是…

vue使用Pinia实现不同页面共享token

文章目录 一、概述二、使用步骤安装pinia在vue应用实例中使用pinia在src/stores/token.js中定义store在组件中使用store登录成功后&#xff0c;将token保存pinia中向后端API发起请求时&#xff0c;携带从pinia中获取的token 三、参考资料 一、概述 Pinia是Vue的专属状态管理库…

通俗版解释CPU、核心、进程、线程、协程的定义及关系

通俗版解释&#xff08;比喻法&#xff09; 1. CPU 和核心 CPU 一个工厂&#xff08;负责干活的总部&#xff09;。核心 工厂里的车间&#xff08;比如工厂有4个车间&#xff0c;就能同时处理4个任务&#xff09;。 2. 进程 进程 一家独立运营的公司&#xff08;比如一家…

用 VS Code / PyCharm 编写你的第一个 Python 程序

用ChatGPT做软件测试 编写你的第一个 Python 程序——不只是“Hello, World”&#xff0c;而是构建认知、习惯与未来的起点 “第一行代码&#xff0c;是一个开发者认知世界的方式。” 编程的入门&#xff0c;不只是运行一个字符串输出&#xff0c;更是开始用计算机思维来理解、…

amd架构主机构建arm架构kkfileview

修改本机使用镜像仓库地址 vim /etc/docker/daemon.json {“experimental”: true, “registry-mirrors”: [ “https://docker.m.daocloud.io”, “https://docker.1panel.live”, “http://mirrors.ustc.edu.cn/”, “http://mirror.azure.cn/”, “https://docker.hpcloud.c…

[Linux] vim及gcc工具

目录 一、vim 1.vim的模式 2.vim的命令集 (1):命令模式 (2):底行模式 3.vim配置 二、gcc 1.gcc格式及选项 2.工作布置 三、自动化构建工具makefile 1.基本使用方法 2.配置文件解析 3.拓展 在linux操作系统的常用工具中&#xff0c;常用vim来进行程序的编写&#xff1b…

数据库3——视图及安全性

视图及安全性 学习内容学习感受 学习内容 一、实验目的与要求&#xff1a; 1、设计用户子模式 2、根据实际需要创建用户角色及用户&#xff0c;并授权 3、针对不同级别的用户定义不同的视图&#xff0c;以保证系统的安全性 二、实验内容&#xff1a; 1、 先创建四类用户角色&…

Oracle数据库如何进行冷备份和恢复

数据库的冷备份指的是数据库处于关闭或者MOUNT状态下的备份&#xff0c;备份文件包括数据文件、日志文件和控制文件。数据库冷备份所用的时间主要受数据库大小和磁盘I/O性能的影响。由于数据库需要关闭才能进行冷备份&#xff0c;所以这种备份技术并不适用724小时的系统。尽管冷…