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 <module>
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 モードを使用したいので、チャンクが利用できない場合は、それらのチャンクを待ちたいと思います。しかし、try except segment または sleep(0.1) を作成すると、クリック音が聞こえるので、これは私が望むものではありません。
私の問題に最適な解決策を提案してください。