使用 Python 把多個(gè) MP4 合成一個(gè)視頻

這兩天群里有個(gè)小伙伴有一個(gè)需求, 就是把很多個(gè)視頻文件 合并成一個(gè). 期間也找了各種軟件, 如格式工廠, 但是只能一次合成50個(gè)文件, 小伙伴有幾千個(gè)文件需要合成, 太繁瑣; 又比如會(huì)聲會(huì)影, 這個(gè)剪輯是很強(qiáng)大, 但是軟件也很大, 對(duì)電腦配置要求也高. 我只需要拼接功能, 割雞焉用牛刀?

人生苦短 我用 Python

這兩天剛好在學(xué)習(xí)用 Python 寫自動(dòng)化測(cè)試. ??轉(zhuǎn)念一想, Python 也很擅長圖形處理, 那處理視頻也不在話下吧, 于是就上網(wǎng)搜了搜, 果然找到了簡單的辦法~

開始安裝使用

主要是利用 moviepy 這個(gè)庫, 里面提供了豐富的功能, 我們只需要使用簡單的拼接函數(shù)

軟件 & 依賴

  • Python
    • moviepy
      • imageio
        • ffmpeg
      • Numpy
      • Decorator
      • tqdm

一、安裝 Python

這個(gè)就不多說了, 直接去官網(wǎng)下載對(duì)應(yīng)的安裝包: https://www.python.org/downloads/release/python-364/

然后雙擊運(yùn)行, 一路 next

二、安裝 moviepy

命令行執(zhí)行:

pip install moviepy

三、安裝 ffmpeg

如果之前沒安裝過 ffmpeg , 這個(gè)時(shí)候?qū)?moviepy 開始使用會(huì)報(bào)錯(cuò)的, 所以我們可以先用 imageio 自帶的方法下載 ffmpeg

新建文本文件:

import imageio
import ssl

# 下面這一句不是必須的, 但是某些情況下訪問 https 會(huì)報(bào)SSL證書不受信任, 加上這一句可以允許通過
ssl._create_default_https_context = ssl._create_unverified_context

# 下載 ffmpeg 組件
imageio.plugins.ffmpeg.download()

把以上代碼保存為 xx.py , 然后在相同目錄執(zhí)行命令:

python3 xx.py

四、開始寫拼接腳本

# 主要是需要moviepy這個(gè)庫
from moviepy.editor import *
import os

# 定義一個(gè)數(shù)組
L = []

# 訪問 video 文件夾 (假設(shè)視頻都放在這里面)
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)
            # 添加到數(shù)組
            L.append(video)

# 拼接視頻
final_clip = concatenate_videoclips(L)

# 生成目標(biāo)視頻文件
final_clip.to_videofile("./target.mp4", fps=24, remove_temp=False)

把上面代碼的 源文件夾 和 目標(biāo)文件名 改成你自己需要的, 然后把以上代碼保存為 concatenate.py 文件, 然后在相同目錄執(zhí)行命令:

python3 concatenate.py

五、等待運(yùn)行完畢, 完結(jié)撒花 ??

等待輸出走到 100% , 視頻就合并好了.

其實(shí) moviepy 還有很多方便的方法, 比如截取視頻:

video = VideoFileClip("xxoo.mp4")

# 剪輯視頻,截取視頻前20秒
video = video.subclip(0,20)

# 剪輯視頻,從10秒開始到視頻結(jié)尾前12秒
video = video.subclip(10, video.duration-12)

六、補(bǔ)充內(nèi)容

上面的拼接代碼實(shí)際上有點(diǎn)小問題, files.sort()把文件排序, 實(shí)際上排出來的結(jié)果是不符合我們正常思維的, 比如: 1.mp4, 10.mp4, 2.mp4. 因?yàn)樗菑那巴笾鹱址容^的, 而我們想要的結(jié)果一般是: 1.mp4, 2.mp4, 10.mp4. 這個(gè)問題除了自己寫各種邏輯代碼來處理, 也可以直接用一個(gè)第三方庫: natsort, 這個(gè)庫提供了優(yōu)秀的自然排序方法.

安裝 natsort:

pip3 install natsort

使用:

  • 導(dǎo)入庫: from natsort import natsorted
  • 把代碼 files.sort() 替換為 files = natsorted(files)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容