通过Python脚本批量复制并规范命名视频文件

2025-03-07 17:50

本文主要是介绍通过Python脚本批量复制并规范命名视频文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《通过Python脚本批量复制并规范命名视频文件》本文介绍了如何通过Python脚本批量复制并规范命名视频文件,实现自动补齐数字编号、保留原始文件、智能识别有效文件等功能,听过代码示例介绍的非常详细,...

一、问题场景:杂乱的视频文件名

在日常工作和学习中,我们经常会遇到这样的文件命名情况:

  • [1]基础教程.mp4
  • [23]进阶技巧.mp4
  • [156]项目实战.mp4

这种包含数字编号的命名方式虽然直观,但存在两个明显问题:

  • 数字位数不一致,排序时会出现顺序错乱
  • 需要修改文件名但必须保留原始文件

本文将介绍如何通过python脚本批量复制并规范命名视频文件,实现:

  • 自动补齐4位数字编号
  • 保留原始文件不修改
  • 智能识别有效文件
  • 完整复制文件属性

二、完整解决方案

import os
import re
import shutil

def rename_and_copy_mp4_files(source_dir, target_dir):
    """智能重命名并复制视频文件
    
    Args:
        source_dir (str): 源目录路径
        target_dir (str): 目标目录路径
    """
    # 创建目标目录(自动处理已存在情况)
    os.makedirs(target_dir, exist_ok=True)
    
    # 遍历源目录所有文件
    for filename in os.listdir(source_dir):
        # 使用正则表达式解析文件名
        pattern_match = re.match(r'\[(\d+)\](.+)\.(mp4|avi|mov)$', filename, re.IGphpNORECASE)
        
        if pattern_match:
            # 提取文件名组件
            file_number = pattern_match.group(1)
            file_content = pattern_match.group(2).strip()
            file_ext = pattern_match.group(3).lower()
            
            # 格式化数字编号(4位补零)
            formatted_number = file_number.zfill(4)
            
            # 构建新文件名
            new_filename = f"{formatted_number}_{file_content}.{file_ext}"
            
            # 构建完整路径
            src_path = os.path.join(source_dir, filename)
            dst_path = os.path.join(target_dir, new_filename)
            
            # 执行带元数据的复制China编程操作
            shutil.copy2(src_path, dst_path)
            print(f"成功处理:{filename} → {new_filename}")
        else:
            print(f"跳过非标准文件:{filename}")

if __name__ == "__main__":
    # 配置路径(根据实际情况修改)
    SOURCE_DIR = r"E:\video_source"
    TARGET_DIR = r"E:\video_organized"
    
    rename_and_copy_mChina编程p4_files(SOURCE_DIR, TARGET_DIR)

三、关键技术解析

1. 智能路径处理

os.makedirs(target_dir, exist_ok=True)

exist_ok=True 参数确保:

  • 目标目录不存在时自动创建
  • 目录已存在时不报错
  • 自动处理多级目录创建

2. 精准文件名匹配

r'\[(\d+)\](.+)\.(mp4|avi|mov)$'

正则表达式分解:

  • \[(\d+)\] 捕获方括号内的数字
  • (.+) 捕获任意长度内容(至少1个字符)
  • (mp4|avi|mov)$ 支持多种视频格式
  • re.IGNORECASE 忽略大小写

支持匹配的格式:

  • [123] 教程.mp4
  • [45]advanced.MOV
  • [6]测试文件.AVI

3. 数字格式化

file_number.zfill(4)

转换示例:

  • “1” → “0001”
  • “23” → “0023”
  • “156” → “0156”

4. 安全文件复制

shutil.copy2(srjsc, dst)

与普通复制的区别:

  • 保留原始创建时间
  • 保留最后修改时间
  • 保留文件权限设置
  • 保留其他元数据

四、使用指南

准备步骤

  • 安装Python 3.6+环境
  • 创建脚本文件 video_organizer.py
  • China编程备测试目录(建议先进行测试)

配置示例

# Windows系统示例
SOURCE_DIR = r"E:\training_videos"
TARGET_DIR = r"D:\sorted_videos"

# MACOS/linux示例
# SOURCE_DIR = "/Users/username/Videos/source"
# TARGET_DIR = "/Volumes/external_drive/sorted_videos"

执行效果

原始文件生成文件
[1]介绍.mp40001_介绍.mp4
[23]基础课.avi0023_基础课.avi
[156]项目实战.mov0156_项目实战.mov

五、高级扩展建议

1. 添加进度提示

# 在循环开始前添加
total_files = len([f for f in os.listdir(source_dir) if f.endswith(('.mp4', '.avi', '.mov'))])
processed = 0

# 在处理成功时添加
processed += 1
print(f"进度:{processed}/{total_files} ({processed/total_files:.1%})")

2. 防覆盖机制

if os.path.exists(dst_path):
    base, ext = os.path.splitext(new_filename)
    counter = 1
    while os.path.exists(dst_path):
        new_filename = f"{base}_{counter}{ext}"
        dst_path = os.path.join(target_dir, new_filename)
        counter += 1

3. 多线程加速

from concurrent.futures import ThreadPoolExecutor

def process_file(filename):
    # 原处理逻辑

with ThreadPoolExecutor(max_workers=4) as executor:
    executor.map(process_file, os.listdir(source_dir))

六、注意事项

  1. 路径格式验证
    • Windows路径使用反斜杠 r"E:\path"
    • 其他系统使用正斜杠 "/path/to/files"

  2. 权限问题
    • 确保对源目录有读取权限
    • 确保对目标目录有写入权限

  3. 特殊字符处理
    • 自动跳过包含非法字符的文件
    • 可添加字符过滤逻辑:

file_content = re.sub(r'[<>:"/\\|?*]', '', file_content)
  1. 性能优化
    • 万级以上文件建议添加:
    ◦ 进度条显示
    ◦ 错误日志记录
    ◦ 断点续传功能

七、总结

通过这个Python脚本,我们实现了:

  • 批量处理视频文件
  • 智能规范编号格式
  • 安全保留原始文件
  • 快速部署使用

扩展应用场景

  • 整理教学视频库
  • 规范监控录像存档
  • 管理影视素材资源
  • 自动化测试视频处理

TIP:建议将此脚本与定时任务结合,打造自动化文件管理系统。欢迎在评论区分享你的使用经验或提出改进建议!

以上就是通过Python脚本批量复制并规范命名视频文件的详细内容,更多关于Python复制并重命名视频文件的资料请关注编程China编程(www.chinasem.cn)其它相关文章!

这篇关于通过Python脚本批量复制并规范命名视频文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达