使用 Python 读取输入声音信号

Reading input sound signal using Python

我需要从插孔连接的麦克风获取声音信号,并使用数据在 Python 中进行即时处理。

处理及后续步骤一目了然。我只是在从程序中获取信号时迷路了。 通道数无关紧要,一个就够了。我不会播放声音,所以声卡上应该不需要 ASIO。

我的问题是:如何从 Python 捕获 Jack 音频? (如果有一个包,有据可查的和小众的例子,那就太好了:-)。

我会考虑使用 pysox,libsox 的 python 绑定。

您可以从 PyPI 获取 pysox package

你试过pyaudio了吗? 安装:

python -m pip install pyaudio

录制示例,来自官网:

PyAudio 示例:录制几秒钟的音频并将其保存到 WAVE 文件。

import pyaudio
import wave

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

此示例在我的笔记本电脑上运行 Python 2.7.11(和 3.5.1),Windows 8.1,pyaudio 0.2.9。

如果要求是 Jack, then you may want to use PyJack,这是 Jack 的 Python 绑定。

此外,源代码中有一个示例可以说明您要执行的操作,即捕获音频。查看文件 capture.py

您必须考虑到,为了避免丢失一个块,您必须每 500 *(buffer_size/sample_rate) 毫秒调用一次 jack.processjack.process 错过音频块(jack.InputSyncErrorjack.OutputSyncError)时抛出异常。

您打算分段或流式从麦克风获取音频吗? 无论哪种情况,都可以使用 sounddevice

您可以使用
安装python模块 pip install sounddevice --user

详情请参考官网API。

sounddevice 将从您的笔记本电脑麦克风(标准音频输入)录制音频并在扬声器或耳机上播放(标准音频输出)。您可以使用声音对象进行进一步处理。

import sounddevice as sd
import numpy as np
import scipy.io.wavfile as wav

fs=44100
duration = 5  # seconds
myrecording = sd.rec(duration * fs, samplerate=fs, channels=2,dtype='float64')
print "Recording Audio"
sd.wait()
print "Audio recording complete , Play Audio"
sd.play(myrecording, fs)
sd.wait()
print "Play Audio Complete"

Here is the Output : Python 2.7.9 (default, Dec 10 2014, 12:24:55) [MSC v.1500 32 bit (Intel)] on win32 Type "copyright", "credits" or "license()" for more information. ================================ RESTART ===================

Recording Audio
Audio recording complete , Play Audio
Play Audio Complete