QQ登录

只需要一步,快速开始

APP扫码登录

只需要一步,快速开始

查看: 3356|回复: 0

[Python] Python多个MP4合成视频的实现方法

[复制链接]

等级头衔

积分成就    金币 : 2861
   泡泡 : 1516
   精华 : 6
   在线时间 : 1321 小时
   最后登录 : 2025-7-9

丰功伟绩

优秀达人突出贡献荣誉管理论坛元老活跃会员

联系方式
发表于 2021-7-16 09:20:40 | 显示全部楼层 |阅读模式
一、安装环境
0 G+ H4 Q, W# k7 Y       主要是利用 moviepy 这个库, 里面提供了丰富的功能, 我们只需要使用简单的拼接函数。直接去官网下载Pyhon对应的安装包:https://www.python.org/downloads/release/python-364/ ,然后双击运行,记得点 Add to Path 然后,一路 next。0 o8 ~7 E( U+ x( y4 A) ]  d4 m
二、安装 moviepy: r% d  t6 i! e# _
       命令行执行:% F2 @) L+ J/ A0 T. ^& x3 ]
pip install moviepy
三、安装 ffmpeg. R+ d! r7 {, b$ d- Z% \
       我们先使用如下命令来尝试安装:' [4 s# H, A* j) F( |( @
pip install ffmpeg
pip install imageio-ffmpeg
      把以上代码保存为 xx.py , 然后在相同目录执行命令:$ x$ ?4 X" d, ]' v( \( s
python3 xx.py
      如果之前没安装过 ffmpeg , 这个时候导入 moviepy 开始使用会报错的, 所以我们可以先用 imageio 自带的方法下载 ffmpeg。- f# Y  N" b* Y1 c2 P
       新建文本文件:
" F; Y% J8 ~7 T, d* L& Y
import imageio
import ssl

# 下面这一句不是必须的, 但是某些情况下访问 https 会报SSL证书不受信任, 加上这一句可以允许通过
ssl._create_default_https_context = ssl._create_unverified_context

# 下载 ffmpeg 组件
imageio.plugins.ffmpeg.download()
四、开始写拼接脚本/ s( E% l5 s# Z5 }" o# Y( a
# 主要是需要moviepy这个库
from moviepy.editor import *
import os

# 定义一个数组
L = []

# 访问 video 文件夹 (假设视频都放在这里面)
for root, dirs, files in os.walk("./video"):
    # 按文件名排序
    files.sort()
    # 遍历所有文件
    for file in files:
        # 如果后缀名为 .mp4
        if os.path.splitext(file)[1] == '.mp4':
            # 拼接成完整路径
            filePath = os.path.join(root, file)
            # 载入视频
            video = VideoFileClip(filePath)
            # 添加到数组
            L.append(video)

# 拼接视频
final_clip = concatenate_videoclips(L)

# 生成目标视频文件
final_clip.to_videofile("./target.mp4", fps=24, remove_temp=False)
      把上面代码的 源文件夹 和 目标文件名 改成你自己需要的, 然后把以上代码保存为 concatenate.py 文件, 然后在相同目录执行命令:8 G4 Q9 D" x4 ~+ x+ ?
python3 concatenate.py
五、等待运行完毕
* f" N& R" d1 N/ r3 X       等待输出走到 100% , 视频就合并好了。
% U0 p9 K1 _1 g4 o- Z; R- ]
Moviepy - Building video ./target.mp4.
8 {; u# n: ?( t6 C, i# DMoviePy - Writing audio in targetTEMP_MPY_wvf_snd.mp3
, ^& ^3 G( ^. k( n" X* w9 h5 ]MoviePy - Done.& M& M" O* T4 w$ N7 b% }
Moviepy - Writing video ./target.mp4$ J( r4 G1 a# ^6 P( I

- l1 J0 X9 F% @3 F3 L$ fMoviepy - Done !! E- i/ ^2 i( g6 U% e
Moviepy - video ready ./target.mp4
    其实 moviepy 还有很多方便的方法, 比如截取视频:* v, z; f5 Z8 q# x# \
video = VideoFileClip("xxoo.mp4")

# 剪辑视频,截取视频前20秒
video = video.subclip(0,20)

# 剪辑视频,从10秒开始到视频结尾前12秒
video = video.subclip(10, video.duration-12)
六、补充内容
% G0 y9 V! u/ q4 R       上面的拼接代码实际上有点小问题, files.sort()把文件排序,实际上排出来的结果是不符合我们正常思维的,比如: 1.mp4, 10.mp4, 2.mp4。因为他是从前往后逐字符比较的,而我们想要的结果一般是: 1.mp4, 2.mp4, 10.mp4。这个问题除了自己写各种逻辑代码来处理,也可以直接用一个第三方库: natsort,这个库提供了优秀的自然排序方法。2 F5 R! [/ b5 ?/ l: h
       安装 natsort:
* V1 j+ a) r1 }( B6 i# @- M
pip3 install natsort
      使用:
$ v2 \/ K& ~/ [. g2 U/ T6 t* U2 h: o
  • 导入库: from natsort import natsorted
  • 把代码 files.sort() 替换为 files = natsorted(files)0 q  j! ]) H, t) W- m
       代码如下:
* i; N: q5 N) K# l  O, e% j- N
"""
project = 'Code', file_name = 'Video_stitching', author = 'AI悦创'
time = '2020/4/25 12:19', product_name = PyCharm, 公众号:AI悦创
# code is far away from bugs with the god animal protecting
    I love animals. They taste delicious.
"""
# 主要是需要moviepy这个库
from moviepy.editor import *
from natsort import natsorted
import os

# 定义一个数组
L = []

# 访问 video 文件夹 (假设视频都放在这里面)
for root, dirs, files in os.walk("./video"):
    # 按文件名排序
    # files.sort()
    files = natsorted(files)
    # 遍历所有文件
    for file in files:
        # 如果后缀名为 .mp4
        if os.path.splitext(file)[1] == '.mp4':
            # 拼接成完整路径
            filePath = os.path.join(root, file)
            # 载入视频
            video = VideoFileClip(filePath)
            # 添加到数组
            L.append(video)

# 拼接视频
final_clip = concatenate_videoclips(L)

# 生成目标视频文件
final_clip.to_videofile("./target.mp4", fps=24, remove_temp=False)
      这样的成功我做出来 MP4 视频的拼接。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|paopaomj.COM ( 渝ICP备18007172号|渝公网安备50010502503914号 )

GMT+8, 2025-8-30 11:16

Powered by paopaomj X3.5 © 2016-2025 sitemap

快速回复 返回顶部 返回列表