在 Python 中对录音进行去除背景噪音处理可以借助不同的库来实现,以下为你详细介绍使用 pydub 和 noisereduce 这两个库的具体方法。
方法一:使用 pydub 和 noisereduce 库noisereduce 是一个专门用于降噪的 Python 库,而 pydub 可以帮助我们读取和保存音频文件。
安装依赖库pip install pydub noisereduce numpy scipy示例代码
import numpy as np
from pydub import AudioSegment
import noisereduce as nr
import soundfile as sf
def reduce_noise(input_file, output_file):
# 读取音频文件
audio = AudioSegment.from_file(input_file)
# 将音频转换为 numpy 数组
audio_data = np.array(audio.get_array_of_samples())
sample_rate = audio.frame_rate
# 提取前 1 秒的音频作为噪声样本(假设前 1 秒是纯噪音)
noise_data = audio_data[:sample_rate]
# 进行降噪处理
reduced_noise = nr.reduce_noise(y=audio_data, sr=sample_rate, noise_clip=noise_data)
# 将处理后的 numpy 数组转换回 AudioSegment 对象
audio_out = AudioSegment(
reduced_noise.tobytes(),
frame_rate=sample_rate,
sample_width=audio.sample_width,
channels=audio.channels
)
# 保存处理后的音频文件
audio_out.export(output_file, format="wav")
# 使用示例
input_file = "input.wav"
output_file = "output.wav"
reduce_noise(input_file, output_file) 代码解释读取音频文件:利用 pydub 的 AudioSegment.from_file 方法读取输入的音频文件。转换为 numpy 数组:把音频数据转换为 numpy 数组,这样就能使用 noisereduce 库进行处理。提取噪声样本:假设音频的前 1 秒是纯噪音,将这部分音频数据提取出来作为噪声样本。降噪处理:调用 noisereduce 的 reduce_noise 方法,传入音频数据、采样率和噪声样本,得到降噪后的音频数据。保存处理后的音频:将处理后的 numpy 数组转换回 AudioSegment 对象,然后使用 export 方法保存为新的音频文件。方法二:使用 librosa 和 noisereduce 库librosa 是一个强大的音频处理库,同样可以和 noisereduce 配合使用进行降噪。
安装依赖库pip install librosa noisereduce soundfile示例代码
import librosa
import noisereduce as nr
import soundfile as sf
def reduce_noise_librosa(input_file, output_file):
# 读取音频文件
audio, sr = librosa.load(input_file, sr=None)
# 提取前 1 秒的音频作为噪声样本(假设前 1 秒是纯噪音)
noise = audio[:sr]
# 进行降噪处理
reduced_noise = nr.reduce_noise(y=audio, sr=sr, noise_clip=noise)
# 保存处理后的音频文件
sf.write(output_file, reduced_noise, sr)
# 使用示例
input_file = "input.wav"
output_file = "output.wav"
reduce_noise_librosa(input_file, output_file) 代码解释读取音频文件:使用 librosa.load 方法读取输入的音频文件,同时获取音频数据和采样率。提取噪声样本:同样假设音频的前 1 秒是纯噪音,将这部分音频数据提取出来作为噪声样本。降噪处理:调用 noisereduce 的 reduce_noise 方法进行降噪。保存处理后的音频:使用 soundfile.write 方法将处理后的音频数据保存为新的音频文件。通过以上两种方法,你可以在 Python 中对录音进行去除背景噪音处理。需要注意的是,不同的音频文件和噪音情况可能需要调整降噪参数以获得更好的效果。
网友回复
如何修改别人发给我的微信笔记内容?
fbx、obj、glb三维格式模型如何在浏览器中通过three相互转换格式?
python如何实现基于http隧道加密的正向代理服务?
有没有有专门针对 UI 界面截图进行智能标记(Set-of-Mark, SoM) 的开源库和工具?
如何用python实现Set-of-Mark (SoM) 技术?
python如何截取windows指定应用的窗口截图,不用管窗口是不是在最前面?
linux能不能给rm删除命令增加回收站功能,可恢复被删文件?
bfwsoa如何在命令行中执行控制器动作器方法?
RAG(检索增强生成)和 KG(知识图谱)有啥不同?
KVM硬件是啥?


