要在Python中使用PyAudio库实现多声道录音,您需要执行以下步骤:
pip install pyaudio
import pyaudio
import wave
import numpy as np
CHUNK = 1024
FORMAT = pyaudio.paInt16
CHANNELS = 2
RATE = 44100
RECORD_SECONDS = 5
WAVE_OUTPUT_FILENAME = "output.wav"
p = pyaudio.PyAudio()
# 打开音频流
stream = p.open(format=FORMAT,
channels=CHANNELS,
rate=RATE,
input=True,
frames_per_buffer=CHUNK)
print("开始录音...")
frames = []
for i in range(0, int(RATE / CHUNK * RECORD_SECONDS)):
data = stream.read(CHUNK)
frames.append(data)
print("录音完成。")
# 停止、关闭并释放资源
stream.stop_stream()
stream.close()
p.terminate()
# 将录音数据保存为WAV文件
wf = wave.open(WAVE_OUTPUT_FILENAME, 'wb')
wf.setnchannels(CHANNELS)
wf.setsampwidth(p.get_sample_size(FORMAT))
wf.setframerate(RATE)
wf.writeframes(b''.join(frames))
wf.close()
print("录音已保存到 {} 文件中。".format(WAVE_OUTPUT_FILENAME))
这个脚本将录制5秒钟的音频,并将其保存到一个名为output.wav
的文件中。请确保在运行此脚本之前已经安装了NumPy库,因为我们在处理音频数据时会用到它。如果尚未安装NumPy,可以使用以下命令安装:
pip install numpy
现在,您可以运行这个脚本来实现多声道录音。