在 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 中对录音进行去除背景噪音处理。需要注意的是,不同的音频文件和噪音情况可能需要调整降噪参数以获得更好的效果。
网友回复
js如何流式输出ai的回答并折叠代码块,点击代码块右侧可预览代码?
ai大模型如何将文章转换成可视化一目了然的图片流程图图表?
大模型生成html版本的ui原型图和ppt演示文档的系统提示词怎么写?
rtsp视频直播流如何转换成websocket流在h5页面上观看?
为啥coze会开源工作流agent coze studio?
如何检测网页是通过收藏夹打开的?
python如何实现类似php的http动态脚本请求处理响应代码?
js如何实现类似php的http动态脚本请求处理响应代码?
trae与solo有啥区别不同?
vue如何让ai动态生成问卷调查多步骤表单式收集基础信息自动规划执行任务?