最近做了一个项目,将从微信下载的音频文件(默认为.amr格式)转化为mp3格式(否则前端播放将会遇到困难)上传到云端。经过一番研究,最终决定采用Python的ffmpy包。
首先是ffmpy的文档:http://ffmpy.readthedocs.io/en/latest/index.html
安装只需执行
pip install ffmpy
注意,ffmpy只是命令行工具FFmpeg的一个包装,若要成功执行任务,还需要安装FFmpeg
在Ubuntu上:
sudo add-apt-repository ppa:kirillshkrogalev/ffmpeg-next
sudo apt-get update
sudo apt-get install ffmpeg
查看是否安装成功:
ffmpeg -versionx
下面是一个很简单的例子,这里没有对转音频的质量等具体参数进行设置,全部都是用的默认选项。建议由这类需求的朋友们参考一下FFmpeg的文档。
@classmethod def transformat_voice(cls, amr_voice_b): from_fn = 'from.amr' to_fn = 'target.mp3' mp3_file = BytesIO() with open(from_fn, 'wb') as f_from: f_from.write(amr_voice_b.getvalue()) ff = ffmpy.FFmpeg(inputs={from_fn: None}, outputs={to_fn: None}) ff.run() with open(to_fn, 'rb') as f_to: f_to.seek(0) mp3_file.write(f_to.read()) os.remove(from_fn) os.remove(to_fn) mp3_file.seek(0) return mp3_file
这里有一点,由于ffmpy只是一个命令行的wrapper,所以无法对BytesIO进行操作,这里只能先把二进制文件写到硬盘上进行操作,转换完后再把文件删除。最后的返回值会是一个BytesIO类型,方便作为后台程序使用。