从PyAudio获取用于Arduino的音量级别
我想以尽可能小的延迟将音量数据从笔记本电脑的音频输入(只是Macbook中的内置麦克风)发送到Arduino 我发现使用PyAudio捕获音频输入并不困难,但该模块的大多数示例都将音频读数保存为wav或其他文件格式。我可以在将其读入PyAudio时直接测量音量,还是需要将其保存到文件并分析该文件?除了音量之外,我不关心音频中的任何其他数据从PyAudio获取用于Arduino的音量级别,audio,arduino,microphone,arduino-uno,pyaudio,Audio,Arduino,Microphone,Arduino Uno,Pyaudio,我想以尽可能小的延迟将音量数据从笔记本电脑的音频输入(只是Macbook中的内置麦克风)发送到Arduino 我发现使用PyAudio捕获音频输入并不困难,但该模块的大多数示例都将音频读数保存为wav或其他文件格式。我可以在将其读入PyAudio时直接测量音量,还是需要将其保存到文件并分析该文件?除了音量之外,我不关心音频中的任何其他数据 非常感谢。您可以实时阅读该卷。为此,请设置录制,但不保存数据,只需对其进行处理。在这里,我将使用Python附带的audioop模块获得每个块的RMS值。(此
非常感谢。您可以实时阅读该卷。为此,请设置录制,但不保存数据,只需对其进行处理。在这里,我将使用Python附带的audioop模块获得每个块的RMS值。(此示例只是PyAudio网页中录制演示的一个修改,包括
audioop.rms
)
当然,如果您不喜欢RMS,audioop还有其他音量测量方法。这个问题怎么会与arduino有关?我想通过串口将我笔记本电脑麦克风的音频音量发送到arduino。我知道了,但在您的问题中,arduino和串口没有任何关系。你的问题是关于python和pyaudio的。谢谢!我最终使用并修改了相同的代码库@汤姆10
import pyaudio
import wave
import audioop
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)
for i in range(0, int(RATE / CHUNK * RECORD_SECONDS)):
data = stream.read(CHUNK)
rms = audioop.rms(data, 2) # here's where you calculate the volume
stream.stop_stream()
stream.close()
p.terminate()