如何使用 pydub 库从 mp3 文件中生成带有 G.711alaw 的 wav?

Posted

技术标签:

【中文标题】如何使用 pydub 库从 mp3 文件中生成带有 G.711alaw 的 wav?【英文标题】:How to generate wav with G.711alaw from a mp3 file using pydub library? 【发布时间】:2013-11-30 13:19:33 【问题描述】:

我正在尝试使用 Pydub 库从 mp3 文件中生成带有 G. 711 alaw 压缩扩展的 wav 文件。 wav 文件正在生成,但未重新采样到频率 8 kHz。我试过以下代码:

from_path = '/home/nikhil/Music/m1.mp3' #this is a mp3 file
to_path = '/home/nikhil/Music/m1.wav' #resulted file
from_format = 'mp3'
to_format = 'wav'
params = ["-acodec", "pcm_alaw", "-ar", "8000"]
Audiosegment.from_file(from_path, from_format).export(to_path, format=to_format, parameters=params)

有人可以帮我吗?

【问题讨论】:

【参考方案1】:

查看导出方法中的代码,发现输出格式为“wav”时不使用ffmpeg

由于内部使用 wav,它只是将音频的内存版本直接写入磁盘(这样做是为了使 ffmpeg 成为可选依赖项,如果您只需要 wav 支持,则不需要安装它)。

我有 2 个想法可以让您解决这个问题:

    使用不同的格式 kwarg,例如“pcm”。我不确定这是否可行,而且我目前的机器上没有 ffmpeg 可供测试,但绝对值得一试。

    from_path = '/home/nikhil/Music/m1.mp3' #this is a mp3 file
    to_path = '/home/nikhil/Music/m1.wav' #resulted file
    from_format = 'mp3'
    to_format = 'pcm'
    params = ["-acodec", "pcm_alaw", "-ar", "8000"]
    AudioSegment.from_file(from_path, from_format).export(to_path, format=to_format, parameters=params)
    

    使用 pydub 的内部机制重新采样到 8kHz:同样,我目前无法正确测试...

    from_path = '/home/nikhil/Music/m1.mp3' #this is a mp3 file
    to_path = '/home/nikhil/Music/m1.wav' #resulted file
    
    seg = AudioSegment.from_mp3(from_path)
    seg = seg.set_frame_rate(8000)
    seg.export(to_path, format="wav")
    

【讨论】:

第二个工作正常..bt 对于第一个当我尝试大胆打开转换后的文件时,它说它的文件无效。

以上是关于如何使用 pydub 库从 mp3 文件中生成带有 G.711alaw 的 wav?的主要内容,如果未能解决你的问题,请参考以下文章

Pydub 导出错误 - 手动选择编码器

pydub,ffmpeg mp4转mp3音频提取

使用 Java ID3 标签库从 MP3 文件中获取图像

python处理音频文件(mp3)

pydub - 内存错误

如何在不实际转换的情况下确定转换后音频文件的理论文件大小(即 mp3 到 wav)