python

python pyaudio 如何实现多声道录音

小樊
94
2024-11-25 21:39:58
栏目: 编程语言

要在Python中使用PyAudio库实现多声道录音,您需要执行以下步骤:

  1. 首先,确保已经安装了PyAudio库。如果没有安装,可以使用以下命令安装:
pip install pyaudio
  1. 接下来,编写一个Python脚本来实现多声道录音。以下是一个示例脚本,它使用两个音频流来捕获左右声道的音频数据:
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

现在,您可以运行这个脚本来实现多声道录音。

0
看了该问题的人还看了