Python从视频提取⾳频的操作
简介
OpenCV中使⽤VideoCapture类写的视频是没有⾳频的,如果要进⼀步处理⾳频则需要⽤到⼀个库——MoviePy,这个库是Python视频编辑库,可裁剪、拼接、标题插⼊、视频合成、视频处理和⾃定义效果。
安装
pip install moviepy
代码
from moviepy.editor import *
video = VideoFileClip('test.mp4')
婴儿陈倩倩audio = video.audio
audio.write_audiofile('test.mp3')
不安装moviepy视频编辑库可以直接使⽤ffmpeg-python库,见参考⽂献4,代码稍微复杂点
⾳频格式
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']},
房间1501
'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四种格式,个⼈测试m4a输出失败,建议只⽤mp3和wav
测试2分钟的视频导出mp3为1.83Mb,wav为20.1Mb
mp3是有损格式,wav是⽆损格式,按需选择
备注
要实现更底层的⾳视频处理应⽤ffmpeg
补充:python处理mp4视频提取⾳频转为mp3或者wav,并进⾏截取陈瑞伤口
mp4视频⽂件提取⾳频转为mp3或者wav⽂件
mp3是有损⽂件,wav是⽆损⽂件,就像我测试的视频,mp3导出只有⼏⼗k,wav⽂件导出有3M多。
from moviepy.editor import *
video = VideoFileClip('aa.mp4')
audio = video.audio
audio.write_audiofile('test.wav')
audio.write_audiofile('test.mp3')
仙剑奇侠传三的主题曲截取map或者wav⽂件
from scipy.io import wavfile
like = ad('test.wav')
# print (like)
# ⾳频结果将返回⼀个tuple。第⼀维参数是采样频率,单位为秒;第⼆维数据是⼀个ndarray表⽰歌曲,如果第⼆维的ndarray只有⼀个数据表⽰单声道,两个数据表⽰⽴体声。所以,通过控制第⼆维数据就能对歌曲进⾏裁剪。# 对like这个元组第⼆维数据进⾏裁剪,所以是like[1];第⼆维数据中是对⾳乐数据切分。 start_s表⽰你想裁剪⾳频的起始时间;同理end_s表⽰你裁剪⾳频的结束时间。乘44100 是因为每秒需要进⾏44100次采样
# 这⾥表⽰对该⾳频的13-48秒进⾏截取
wavfile.write('test2.wav',44100,like[1][13*44100:48*44100])
打架舞
以上为个⼈经验,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。如有错误或未考虑完全的地⽅,望不吝赐教。