這兩天群里有個(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
- imageio
- moviepy
一、安裝 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)