我必须在不使用任何外部 Python 库的情况下将 wav 文件从 44100Hz 下采样到 16000Hz,因此最好使用 wave
和/或 audioop
。我尝试使用 setframerate
函数将 wav 文件的帧速率更改为 16000,但这只会减慢整个录制速度。我怎样才能将音频文件下采样到 16kHz 并保持相同的音频长度?
最佳答案
您可以使用 Librosa 的 load() 函数,
import librosa
y, s = librosa.load('test.wav', sr=8000) # Downsample 44.1kHz to 8kHz
安装 Librosa 的额外努力可能值得安心。
专业提示:在 Anaconda 上安装 Librosa 时,您需要 install ffmpeg同样,所以
pip install librosa
conda install -c conda-forge ffmpeg
这可以避免 NoBackendError() 错误。
关于python - 下采样 wav 音频文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30619740/