ubuntu - python mp3流如何转无损wav?
问题描述
我用百度语音webapi将文字转成语音,百度webapi只支持返回mp3格式的流,但是我想要在实时简单分析下波形,用FFT处理下。所以想要将mp3流转为无损的wav格式。但是找了如下的python包,pymedia官方已经不更新,貌似不支持python2.7了,非官方的没试;pymad和pyogg没有找到文档,也没有mp3转无损格式的demo。请问有什么解决方法吗?
问题解答
回答1:自问自答,希望对碰到同样情况的有帮助,也欢迎提出修改意见,或者更好的方案。据这几天的搜索很少有模块显示地支持音频流格式转换。找到一个可用的模块io,声音处理模块可以参考https://wiki.python.org/moin/...
import ioaud=io.BytesIO(data)#data的格式是mp3数据的bytestring
然后可以像用文件一样使用这段流数据,之后就可以使用mp3文件转wav的模块,而不用写入到文件再读。
以下是结合pydub验证过程:
from pydub import AudioSegment ###需要安装pydub、ffmpegimport waveimport io#先从本地获取mp3的bytestring作为数据样本fp=open('/home/dyan/你好.mp3',’rb’)data=fp.read()fp.close()#主要部分aud=io.BytesIO(data)sound=AudioSegment.from_file(aud,format=’mp3’)raw_data = sound._data#写入到文件,验证结果是否正确。l=len(raw_data)f=wave.open('/home/dyan/123.wav',’wb’)f.setnchannels(1)f.setsampwidth(2)f.setframerate(16000)f.setnframes(l)f.writeframes(raw_data)f.close()
相关文章:
1. git - 在web应用分布式部署的情况下怎么进行配置更新2. css3 - 微信前端页面遇到的transition过渡动画的bug3. css - 文字排版问题,内容都是动态抓出来的,字数不一定。如何对齐啊4. 网页爬虫 - 关于Python的编码与解码问题5. css3 - 微信小程序如何把radio改成2个选择按钮的样式6. javascript - imgzoom插件所引发的bug血案!!!!7. php - TP5的登录验证问题8. selenium-selenium-webdriver - python 将当前目录加入到 环境变量9. javascript - html5 input file 如何限制只能调起图库和摄像头、不能选择其他类型的文件?10. css - input间的间距和文字上下居中

网公网安备