从字节读取而不是文件名转换音频

时间:2017-06-08 00:40:15

标签: python pydub

我将MongoDB中的小型声音文件存储为BSON。 任务是从数据库中检索二进制数据,将其转换为适当的格式并发送回前端。 问题在于转换。我发现可以使用pydub

我的代码如下

 query_param = json_data['retriever']
 query_param1 = query_param.replace('"', "");
 data = db.soundData
 y = data.find_one({'name': query_param1})
 s = y['data'] // here I retrieve the binary data 
 AudioSegment.from_file(s).export(x, format="mp3")
 return send_file(x, 'audio/mp3')

问题在于Audiosegment系列,因为它不符合标准 AudioSegment.from_wav("/input/file.wav").export("/output/file.mp3", format="mp3") 并且仍然抛出'bytes' object has no attribute 'read'的错误。 pydub可以实现吗?

1 个答案:

答案 0 :(得分:4)

AudioSegment.from_file()将文件路径或类文件对象作为其第一个参数。假设您有整个波形文件的原始字节(包括波形标题,而不仅仅是音频数据),那么您可以:

import io
s = io.BytesIO(y['data'])
AudioSegment.from_file(s).export(x, format='mp3')

如果您只有音频样本的字节,则需要了解有关音频数据的一些元数据:

AudioSegment(y['data'], sample_width=???, frame_rate=???, channels=???)
  • sample_width是每个样本中的字节数(因此,对于16位/ CD音频,您使用2
  • frame_rate是样本数/秒(又名采样率,对于CD音频而言是44100
  • channels有多少音频流,立体声为2,单声道为1