如何在python中规范化音频文件的音量:当前可用的任何包?

时间:2017-02-27 17:37:14

标签: python audio ffmpeg aac replaygain

我有一堆AAC(.m4a)音频文件需要规范化,并希望找到一种方法,使用一些软件包使用一个简单的python脚本。我在超级用户上找到了this thread,其中有人在python中编写了ffmpeg命令行实用程序,它运行良好,但是想知道是否有一些当前可用的 pip install这将取决于任务。

2 个答案:

答案 0 :(得分:8)

您可以使用pydub模块以最少的代码量实现峰值音量的标准化。 使用

安装pydub
pip install pydub

来自here

的灵感

您可以在pydub中测量rms,它是平均幅度的度量,pydub提供为audio_segment.rms。它还提供了一种将值转换为dBFS(audio_segment.dBFS)

的便捷方法

如果您希望音频文件具有相同的平均幅度,基本上您可以选择平均幅度(在下面的示例中以dBFS,-20为单位),并根据需要进行调整:

from pydub import AudioSegment

def match_target_amplitude(sound, target_dBFS):
    change_in_dBFS = target_dBFS - sound.dBFS
    return sound.apply_gain(change_in_dBFS)

sound = AudioSegment.from_file("yourAudio.m4a", "m4a")
normalized_sound = match_target_amplitude(sound, -20.0)
normalized_sound.export("nomrmalizedAudio.m4a", format="mp4")

答案 1 :(得分:3)

from pydub import AudioSegment, effects  

rawsound = AudioSegment.from_file("./input.m4a", "m4a")  
normalizedsound = effects.normalize(rawsound)  
normalizedsound.export("./output.wav", format="wav")

之前:

Before image

之后:

After image