Python多個(gè)MP4合成視頻的實(shí)現(xiàn)方法
開始安裝使用
主要是利用 moviepy 這個(gè)庫(kù), 里面提供了豐富的功能, 我們只需要使用簡(jiǎn)單的拼接函數(shù)
一、安裝 Python
這個(gè)就不多說了, 直接去官網(wǎng)下載對(duì)應(yīng)的安裝包: https://www.python.org/downloads/release/python-364/
然后雙擊運(yùn)行,記得點(diǎn) Add to Path 然后,一路 next
二、安裝 moviepy
命令行執(zhí)行:
pip install moviepy
三、安裝 ffmpeg
我們先使用如下命令來嘗試安裝:
pip install ffmpeg pip install imageio-ffmpeg
把以上代碼保存為 xx.py , 然后在相同目錄執(zhí)行命令:
python3 xx.py
如安裝不成功,可以試一試以下操作:
如果之前沒安裝過 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()
四、開始寫拼接腳本
# 主要是需要moviepy這個(gè)庫(kù)
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% , 視頻就合并好了。
Moviepy - Building video ./target.mp4. MoviePy - Writing audio in targetTEMP_MPY_wvf_snd.mp3 MoviePy - Done. Moviepy - Writing video ./target.mp4 Moviepy - Done ! Moviepy - video ready ./target.mp4
其實(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è)第三方庫(kù): natsort,這個(gè)庫(kù)提供了優(yōu)秀的自然排序方法。
安裝 natsort:
pip3 install natsort
使用:
- 導(dǎo)入庫(kù): from natsort import natsorted
- 把代碼 files.sort() 替換為 files = natsorted(files)
代碼如下:
"""
project = 'Code', file_name = 'Video_stitching', author = 'AI悅創(chuàng)'
time = '2020/4/25 12:19', product_name = PyCharm, 公眾號(hào):AI悅創(chuàng)
# code is far away from bugs with the god animal protecting
I love animals. They taste delicious.
"""
# 主要是需要moviepy這個(gè)庫(kù)
from moviepy.editor import *
from natsort import natsorted
import os
# 定義一個(gè)數(shù)組
L = []
# 訪問 video 文件夾 (假設(shè)視頻都放在這里面)
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)
# 添加到數(shù)組
L.append(video)
# 拼接視頻
final_clip = concatenate_videoclips(L)
# 生成目標(biāo)視頻文件
final_clip.to_videofile("./target.mp4", fps=24, remove_temp=False)
這樣的成功我做出來 MP4 視頻的拼接。
到此這篇關(guān)于Python把多個(gè)MP4合成一個(gè)視頻的文章就介紹到這了,更多相關(guān)Python MP4合成視頻內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
django如何計(jì)算兩個(gè)TimeField的時(shí)差
在Django中,可以使用datetime模塊來計(jì)算兩個(gè)TimeField字段的時(shí)間差,下面通過示例代碼介紹django?計(jì)算兩個(gè)TimeField的時(shí)差,需要的朋友可以參考下2023-05-05
Django生成PDF文檔顯示網(wǎng)頁上以及PDF中文顯示亂碼的解決方法
今天小編就為大家分享一篇Django生成PDF文檔顯示網(wǎng)頁上以及PDF中文顯示亂碼的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12
Python實(shí)現(xiàn)數(shù)據(jù)清洗的示例詳解
這篇文章主要通過五個(gè)示例帶大家深入了解下Python實(shí)現(xiàn)數(shù)據(jù)清洗的具體方法,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Python有一定幫助,需要的可以參考一下2022-08-08
淺談keras中的keras.utils.to_categorical用法
這篇文章主要介紹了淺談keras中的keras.utils.to_categorical用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07
tensorflow模型文件(ckpt)轉(zhuǎn)pb文件的方法(不知道輸出節(jié)點(diǎn)名)
這篇文章主要介紹了tensorflow模型文件(ckpt)轉(zhuǎn)pb文件(不知道輸出節(jié)點(diǎn)名),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04

