我正试图在python中实时绘制声音。我需要从麦克风上取下块。
使用PyAudio,尝试使用
import pyaudio
import wave
import sys
chunk = 1024
FORMAT = pyaudio.paInt16
CHANNELS = 1
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 "* recording"
all = []
for i in range(0, RATE / chunk * RECORD_SECONDS):
data = stream.read(chunk)
all.append(data)
print "* done recording"
stream.close()
p.terminate()
之后,我得到了以下错误:
* recording
Traceback (most recent call last):
File "gg.py", line 23, in
data = stream.read(chunk)
File "/usr/lib64/python2.7/site-packages/pyaudio.py", line 564, in read
return pa.read_stream(self._stream, num_frames)
IOError: [Errno Input overflowed] -9981
我无法理解这个缓冲区。我想要使用阻塞IO模式,所以如果没有块,我想等待那些块。但是当我创建尝试除了段或睡眠(0.1),我听到点击,所以这不是我想要的。
请为我的问题建议最好的解决方案?