Python從視頻中提取音頻的操作
OpenCV中使用VideoCapture類寫的視頻是沒有音頻的,如果要進(jìn)一步處理音頻則需要用到一個(gè)庫——MoviePy,這個(gè)庫是Python視頻編輯庫,可裁剪、拼接、標(biāo)題插入、視頻合成、視頻處理和自定義效果。
安裝pip install moviepy代碼
from moviepy.editor import *video = VideoFileClip(’test.mp4’)audio = video.audioaudio.write_audiofile(’test.mp3’)
不安裝moviepy視頻編輯庫可以直接使用ffmpeg-python庫,見參考文獻(xiàn)4,代碼稍微復(fù)雜點(diǎn)
音頻格式extensions_dict = { 'mp4': {’type’:’video’, ’codec’:[’libx264’,’libmpeg4’, ’aac’]}, ’ogv’: {’type’:’video’, ’codec’:[’libtheora’]}, ’webm’: {’type’:’video’, ’codec’:[’libvpx’]}, ’avi’: {’type’:’video’}, ’mov’: {’type’:’video’}, ’ogg’: {’type’:’audio’, ’codec’:[’libvorbis’]}, ’mp3’: {’type’:’audio’, ’codec’:[’libmp3lame’]}, ’wav’: {’type’:’audio’, ’codec’:[’pcm_s16le’, ’pcm_s24le’, ’pcm_s32le’]}, ’m4a’: {’type’:’audio’, ’codec’:[’libfdk_aac’]} }
可看到支持ogg、mp3、wav和m4a四種格式,個(gè)人測試m4a輸出失敗,建議只用mp3和wav
測試2分鐘的視頻導(dǎo)出mp3為1.83Mb,wav為20.1Mb
mp3是有損格式,wav是無損格式,按需選擇
備注要實(shí)現(xiàn)更底層的音視頻處理應(yīng)用ffmpeg
補(bǔ)充:python處理mp4視頻提取音頻轉(zhuǎn)為mp3或者wav,并進(jìn)行截取
mp4視頻文件提取音頻轉(zhuǎn)為mp3或者wav文件
mp3是有損文件,wav是無損文件,就像我測試的視頻,mp3導(dǎo)出只有幾十k,wav文件導(dǎo)出有3M多。
from moviepy.editor import *video = VideoFileClip(’aa.mp4’)audio = video.audioaudio.write_audiofile(’test.wav’)audio.write_audiofile(’test.mp3’)
截取map或者wav文件
from scipy.io import wavfilelike = wavfile.read(’test.wav’)# print (like)# 音頻結(jié)果將返回一個(gè)tuple。第一維參數(shù)是采樣頻率,單位為秒;第二維數(shù)據(jù)是一個(gè)ndarray表示歌曲,如果第二維的ndarray只有一個(gè)數(shù)據(jù)表示單聲道,兩個(gè)數(shù)據(jù)表示立體聲。所以,通過控制第二維數(shù)據(jù)就能對歌曲進(jìn)行裁剪。# 對like這個(gè)元組第二維數(shù)據(jù)進(jìn)行裁剪,所以是like[1];第二維數(shù)據(jù)中是對音樂數(shù)據(jù)切分。 start_s表示你想裁剪音頻的起始時(shí)間;同理end_s表示你裁剪音頻的結(jié)束時(shí)間。乘44100 是因?yàn)槊棵胄枰M(jìn)行44100次采樣# 這里表示對該音頻的13-48秒進(jìn)行截取wavfile.write(’test2.wav’,44100,like[1][13*44100:48*44100])
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. 讓chatgpt將html中的圖片轉(zhuǎn)為base64方法示例2. 《CSS3實(shí)戰(zhàn)》筆記--漸變設(shè)計(jì)(一)3. CSS3實(shí)現(xiàn)動態(tài)翻牌效果 仿百度貼吧3D翻牌一次動畫特效4. ASP.NET MVC把數(shù)據(jù)庫中枚舉項(xiàng)的數(shù)字轉(zhuǎn)換成文字5. 移動端HTML5實(shí)現(xiàn)拍照功能的兩種方法6. ASP.NET Core自定義中間件的方式詳解7. 測試模式 - XSL教程 - 58. html5手機(jī)觸屏touch事件介紹9. 用xslt+css讓RSS顯示的跟網(wǎng)頁一樣漂亮10. 教你JS更簡單的獲取表單中數(shù)據(jù)(formdata)
