FFMPEG视频转图片

用FFMPEG视频转图片,并且for循环

复制代码
import os
import subprocess

# 输入文件夹和输出文件夹路径
input_folder = r"I:\xxx"
output_base_folder = r"D:\xxx\YOLO\data\video"
output_subfolder_name = "20240609"

# 创建输出子文件夹
output_folder = os.path.join(output_base_folder, output_subfolder_name)
os.makedirs(output_folder, exist_ok=True)

# 循环处理输入文件夹中的所有视频文件
for file_name in os.listdir(input_folder):
    # 检查是否是视频文件(扩展名可根据需要增加)
    if file_name.lower().endswith(('.mp4', '.mov', '.avi', '.mkv')):
        input_path = os.path.join(input_folder, file_name)
        output_name = os.path.splitext(file_name)[0]  # 去掉扩展名
        output_path_pattern = os.path.join(output_folder, f"{output_name}_frame_%04d.jpg")

        # 构建 FFmpeg 命令
        ffmpeg_command = [
            "ffmpeg",
            "-i", input_path,            # 输入视频路径
            "-vf", "fps=5",              # 每秒提取 5 帧
            "-q:v", "2",                 # 高质量图片
            output_path_pattern          # 输出图片路径模式
        ]

        # 打印当前正在处理的文件
        print(f"Processing video: {input_path} -> {output_folder}")
        
        # 执行 FFmpeg 命令
        subprocess.run(ffmpeg_command, check=True)

print("视频处理完成!图片已保存到:", output_folder)

改进以后的代码

python 复制代码
import os
import subprocess

# 输入文件夹和输出文件夹路径
input_folder = r"H:\\xxxx"
output_base_folder = r"D:\\xxx"
output_subfolder_name = os.path.split(os.path.dirname(input_folder))[1]

# 创建输出子文件夹
output_folder = os.path.join(output_base_folder, output_subfolder_name)
os.makedirs(output_folder, exist_ok=True)

# 记录成功和失败的文件
processed_videos = []
skipped_videos = []

# 循环处理输入文件夹中的所有视频文件
for file_name in os.listdir(input_folder):
    # 检查是否是视频文件(扩展名可根据需要增加)
    if file_name.lower().endswith(('.mp4')):
        input_path = os.path.join(input_folder, file_name)
        output_name = os.path.splitext(file_name)[0]  # 去掉扩展名
        output_path_pattern = os.path.join(output_folder, f"{output_name}_frame_%04d.jpg")

        # 构建 FFmpeg 命令
        ffmpeg_command = [
            "ffmpeg",
            "-i", input_path,            # 输入视频路径
            "-vf", "fps=1",              # 每秒提取 1 帧
            "-q:v", "2",                 # 高质量图片
            output_path_pattern          # 输出图片路径模式
        ]

        try:
            print(f"Processing video: {input_path} -> {output_folder}")
            subprocess.run(ffmpeg_command, check=True)
            processed_videos.append(file_name)
        except subprocess.CalledProcessError as e:
            print(f"Error processing {input_path}: {e}")
            skipped_videos.append(file_name)

# 保存处理结果到文件
with open(os.path.join(output_folder, "processed_videos.txt"), "w") as processed_file:
    processed_file.write("\n".join(processed_videos))

with open(os.path.join(output_folder, "skipped_videos.txt"), "w") as skipped_file:
    skipped_file.write("\n".join(skipped_videos))

print("处理完成!")
print(f"成功处理的视频列表已保存到: {os.path.join(output_folder, 'processed_videos.txt')}")
print(f"跳过的视频列表已保存到: {os.path.join(output_folder, 'skipped_videos.txt')}")
相关推荐
顾道长生'8 小时前
(Arxiv-2025)BINDWEAVE:通过跨模态整合实现主体一致性的视频生成
音视频
2301_7644413314 小时前
Streamlit搭建内网视频通话系统
python·https·音视频
xiaohai@Linux17 小时前
STM32上使用HAL库完美实现驱动MAX98357声卡模块(I2S+DMA+音频环形缓冲区)
stm32·单片机·嵌入式硬件·音视频
EasyCVR20 小时前
构筑码头数字防线:视频汇聚平台EasyCVR全方位码头海岸线监管方案
音视频
TG:@yunlaoda360 云老大21 小时前
谷歌发布 Veo 3.1 视频生成模型:有声电影、长视频叙事与人物定制的实测与展望
人工智能·音视频·googlecloud
听雨~の(>^ω^<1 天前
OSTrack视频单目标跟踪
人工智能·目标跟踪·音视频
Hi202402171 天前
消除FFmpeg库的SONAME依赖
linux·ffmpeg
艾思软件-app开发公司1 天前
多平台视频下载工具的实现原理与技术实践, 免费下载视频下载工具
音视频·视频·视频下载·视频下载工具
国服第二切图仔2 天前
鸿蒙 Next 如何使用 AVRecorder 从0到1实现视频录制功能(ArkTS)
华为·音视频·harmonyos
小正太浩二2 天前
视频去动态水印软件HitPaw安装和使用教程
音视频·视频无水印软件