FFmpeg实现文件夹多视频合并

'''
ffmpeg version 6.1.1
要求: 合并的视频同分辨率、同帧率
命令: python 多文件夹多视频合并.py --input_videos D:\videos --output_videos D:\out_videos --output_txts D:\out_txt

要求视频文件夹输入目录:
    --videos
        --test1
            001.mp4
            002.mp4
        --test2
            001.mp4
            002.mp4

输出目录(自动创建文件夹):
    --output_videos
        test1_sum.mp4
        test2_sum.mp4
    --output_txts
        test1.txt
        test2.txt
'''
import argparse
import subprocess  
import os

# 创建ffmpeg输入txt
def create_input_txt(path_in, path_out_txt):
    for dir in os.listdir(path_in):
        try:
            with open(os.path.join(path_out_txt , '{}.txt'.format(dir)), 'w', encoding='utf-8') as f:
                path_dir = os.path.join(path_in, dir)
                for file_name in os.listdir(path_dir):
                        if file_name.split('.')[-1] in ['mp4', 'avi']:
                            f.write(f"file '{os.path.join(path_dir, file_name)}'\n")

            print(f"视频文件夹 {dir} 创建合并txt成功!")
        except Exception as e:
             print(f"视频文件夹 {dir} 创建合并txt失败!")
             print(e)



def run(sum_txt_path, out_video_path):
  
    # 创建一个新的进程  
    p = subprocess.Popen(["ffmpeg", "-f", "concat", "-safe", "0", "-i", f"{sum_txt_path}", "-c", "copy", f"{out_video_path}"], stdout=subprocess.PIPE, stderr=subprocess.STDOUT, text=True)
    # 实时打印输出  
    # for line in p.stdout:  
    #     print(line, end='')  # end='' 防止打印额外的换行符  
    
    # 等待进程结束  
    p.wait()


if __name__ == '__main__':
    parser = argparse.ArgumentParser()
    parser.add_argument('--input_videos', type=str, default='D:\videos', help='视频输入路径')
    parser.add_argument('--output_videos', type=str, default='D:\out_videos', help='视频保存路径,自动创建')
    parser.add_argument('--output_txts', type=str, default='D:\out_txt', help='ffmpeg视频txt保存路径,自动创建')
    
    args = parser.parse_args()

    if not os.path.exists(args.output_videos):
         os.mkdir(args.output_videos)
    if not os.path.exists(args.output_txts):
         os.mkdir(args.output_txts)
    
    create_input_txt(args.input_videos, args.output_txts)

    for txt_name in os.listdir(args.output_txts):
        try:
            if os.path.exists(os.path.join(args.output_videos, txt_name.split('.')[0] + '_sum.mp4')):
                print(f"{txt_name.split('.')[0] + '_sum.mp4'}已存在!, 跳过!")
                continue
            run(os.path.join(args.output_txts, txt_name), os.path.join(args.output_videos, txt_name.split('.')[0] + '_sum.mp4'))
            print(f"{txt_name.split('.')[0] + '_sum.mp4'} 生成成功!")
        except Exception as e:
            print(f"{txt_name.split('.')[0] + '_sum.mp4'} 生成失败!")
            print(e)

参考:ffmpeg实现多视频合并

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Python和FFmpeg合并B站视频,您可以按照以下步骤操作: 1. 首先,您需要安装Python的相关库和FFmpeg。您可以使用pip命令在终端中安装Python库,如有需要,可以使用官方文档检查所需库的正确名称。FFmpeg可以从其官方网站下载,并根据您的操作系统进行安装。 2. 在安装完成后,您需要确定要合并的B站视频的位置。在代码中,您可以使用Python的os库来处理文件和文件夹的路径。 3. 接下来,您可以使用subprocess库来运行FFmpeg命令。您可以使用subprocess.Popen()函数,并通过您的FFmpeg命令作为参数传递给它。 4. 在运行合并命令之前,您需要使用FFmpeg的concat协议来创建一个文本文件,其中包含要合并视频文件的列表。您可以使用Python的open()函数来创建一个.txt文件,并在其中写入视频文件的路径。 5. 编写一个Python函数来执行这些步骤。该函数可以接受两个参数,即要合并视频文件夹路径和合并视频的文件名。 6. 使用Python的os库来获取文件夹中的视频文件列表。 7. 使用subprocess库来运行FFmpeg命令,使用concat协议将视频文件合并为一个文件。命令中会使用刚才生成的包含视频列表的txt文件。 8. 最后,您可以在代码中调用该函数,并传递视频文件夹路径和合并视频的文件名。 请注意,由于B站视频的特殊格式和保护措施,可能需要额外的处理步骤来解码和处理B站视频文件。此外,需要根据FFmpeg的版本和操作系统的要求对命令进行相应的调整。 通过以上步骤,您就可以使用Python和FFmpeg成功合并B站视频了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值