这篇文章给大家分享的是有关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']}, '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 = wavfile.read('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])
感谢各位的阅读!关于“Python从视频中提取音频的操作方法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。