PyAudioでスピーカーの出力を録音する 質問する

PyAudioでスピーカーの出力を録音する 質問する

PyAudio を使用してコンピューターのスピーカーからの出力を録音しようとしています。PyAudio
のドキュメントに記載されているコード例を変更しようとしましたが、うまくいきません。

技術的には、エラーはありません。ファイルを取得しoutput.wavて開くことはできますが、音が出ません。Audacity では、直線しか見えません。

何が問題なのですか?

import pyaudio
import wave

CHUNK = 1024
FORMAT = pyaudio.paInt16
CHANNELS = 2
RATE = 44100
RECORD_SECONDS = 5
WAVE_OUTPUT_FILENAME = "output.wav"

p = pyaudio.PyAudio()

SPEAKERS = p.get_default_output_device_info()["hostApi"] #The part I have modified

stream = p.open(format=FORMAT,
                channels=CHANNELS,
                rate=RATE,
                input=True,
                frames_per_buffer=CHUNK,
                input_host_api_specific_stream_info=SPEAKERS) #The part I have modified

print("* recording")

frames = []

for i in range(0, int(RATE / CHUNK * RECORD_SECONDS)):
    data = stream.read(CHUNK)
    frames.append(data)

print("* done recording")

stream.stop_stream()
stream.close()
p.terminate()

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()

ベストアンサー1

もし誰かがまだ私のようにこれにつまずいている場合のために、私はPyAudio フォークWindows に出力を記録します。

説明:

公式の PyAudio ビルドでは出力を録音できません。ただし、Windows Vista 以降では、新しい API である WASAPI が導入され、ループバック モードで出力デバイスへのストリームを開く機能が含まれています。このモードでは、ストリームは入力ストリームのように動作し、出力されるオーディオ ストリームを録音できます。

モードを設定するには、特別なフラグ(AUDCLNT_STREAMFLAGS_LOOPBACK)。このフラグは公式ビルドではサポートされていないため、ループバック サポートを追加するには、PortAudio と PyAudio を編集する必要があります。

新しいオプション:

"as_loopback":(true|false)

おすすめ記事