av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

python基于moviepy實現(xiàn)音視頻剪輯

瀏覽:2日期:2022-06-16 17:43:33
目錄實踐步驟完整代碼參考實踐步驟

1.尋找合適的Python庫(安裝是否麻煩、使用是否簡便、執(zhí)行會不會太久)

moviepy 音視頻庫。分析需要用的API:代碼示例

2.定義輸入輸出

輸入:一個音視頻文件的地址,需要剪出來的時間段 輸出:剪輯片段的文件

3.設(shè)計執(zhí)行流程并一步步實現(xiàn)(定義函數(shù),與使用具體API相關(guān))

讀入并創(chuàng)建clip對象。 剪輯subclip,輸入時間參數(shù)可以是時間格式的字符串。 導(dǎo)出write_videofile。

4.結(jié)論:時間太久,片段多長就花了多久的時間;CPU全跑滿了。

stackoverflowConcat videos too slow using Python MoviePY 里面有個答案說,調(diào)用包里封裝的ffmpeg函數(shù)會快一些:

You have some functions that perform direct calls to ffmpeg: github.com/Zulko/movie… And are therefore extremely efficient, for simple tasks such as yours.

5.重新設(shè)計和實現(xiàn),直接使用moviepy.video.io.ffmpeg_tools里的函數(shù):ffmpeg_extract_subclip(源音視頻文件,起,止,輸出名)。

這個函數(shù)中輸入的起止時間參數(shù)只能是數(shù)字,不能是字符串,而庫基本使用的接口函數(shù)傳入的是字符串。看源碼發(fā)現(xiàn)是有個把時間字符串轉(zhuǎn)換成數(shù)字的裝飾器的,一步步找就可以找到那個轉(zhuǎn)換的函數(shù)了。

6.結(jié)論:時間快了很多,幾乎是幾秒內(nèi)就完成。

但并不明白為什么快了這么多

7.優(yōu)化:一次處理多個時間段

輸入由一個起止時間,變?yōu)橐唤M起止時間 循環(huán)處理每一組起止時間 輸出的文件名按順序拼接

8.優(yōu)化:每段時間配上名字

輸入除了每一組的起止時間,還有后綴名 文件名+后綴得到輸出的文件名

9.優(yōu)化:輸入輸出的合法性校驗

校驗輸入地址是合法文件 校驗時間段(沒什么必要) 不可以小于0不可以大于視頻時間起小于止完整代碼

需要pip install moviepy

簡單的使用

from moviepy.editor import VideoFileClip, concatenate_videoclipsclipOri = VideoFileClip('E:/2020-03-29 19-31-39.mkv')#截取兩個subclip再拼接#time_length = int(clipOri.duration) 這句可以獲取片子的時#超過時長會報錯,時長默認(rèn)用秒,也可以寫得更細(xì),(00:03:50.54)->3分50秒cut1 = clipOri.subclip(0, 7053)cut2 = clipOri.subclip(7059, 8941)finalClip = concatenate_videoclips([cut1,cut2])finalClip.write_videofile('E:/acut.mp4')

import osimport moviepy.video.io.ffmpeg_tools as fftoolfrom moviepy.tools import cvsecsdef add_suffix(file_name, suffix): # 文件名拼接后綴 index = file_name.rfind(’.’) # 最后一個點號 res = file_name[:index] + ’_’ + suffix + file_name[index:] return res# 輸入file_name = r'./XXX.mkv'output_arr = [ (’04:20’,’05:07’, ’自我介紹’), (’05:07’,’17:47’, ’項目經(jīng)歷’), (’17:37’,’24:40’, ’HTTPS’), (’24:40’,’28:10’, ’實現(xiàn)讀寫鎖’),]if not os.path.isfile(file_name): # 校驗 print('不合法的輸入', file_name)for startStr, endStr, suffix in output_arr: start = cvsecs(startStr) end = cvsecs(endStr)if start < 0 or start >= end: # 校驗print('不合法的時間',startStr, endStr)continue full_output_name = add_suffix(file_name, suffix) print(’處理文件:’, file_name, ’時間:’, startStr, ’-’, endStr) fftool.ffmpeg_extract_subclip(file_name,start,end,full_output_name) # 剪輯并輸出 print(’處理功成功,輸出:’,full_output_name)參考 moviepy的文檔 moviepy中文文檔英文文檔GitHub地址 博文:用moviepy將視頻剪掉一段stack overflow Concat videos too slow using Python MoviePY

以上就是python基于moviepy實現(xiàn)音視頻剪輯的詳細(xì)內(nèi)容,更多關(guān)于python moviepy實現(xiàn)音視頻剪輯的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 亚洲国产精品一区二区久久 | 黄色欧美视频 | 欧美专区在线 | 久久精品亚洲精品国产欧美 | 中文字幕亚洲视频 | 国产线视频精品免费观看视频 | 狠狠操在线 | 亚洲精品国产精品国自产在线 | 亚洲人人| 久久久精品黄色 | 久久久性色精品国产免费观看 | 99在线观看视频 | 天天操妹子 | 91久久久久久久久久久 | 欧美亚洲成人网 | 久久午夜电影 | 欧洲亚洲一区 | 亚洲精品国产偷自在线观看 | 亚洲精品国产电影 | 亚洲精选一区 | 久久69精品久久久久久国产越南 | 免费色网址 | 四季久久免费一区二区三区四区 | 一区二区三区四区在线视频 | 91人人视频在线观看 | 91久久精品日日躁夜夜躁欧美 | 午夜精品网站 | 国产伦精品一区二区三区精品视频 | 视频一二三区 | 日韩成人在线观看 | 成人免费一区二区三区视频网站 | 在线观看中文字幕 | 91社区在线观看播放 | 欧美在线观看一区 | 国产精品69久久久久水密桃 | 欧美日韩精品一区 | 欧美一区二 | 成人精品一区二区三区中文字幕 | 一区二区三区在线看 | 黄网站在线播放 | 国产精品日韩欧美一区二区三区 |