46

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

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

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

4

4 回答 4

68

你试过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()

这个例子在我的笔记本电脑上运行,在 Windows 8.1 中使用 Python 2.7.11(和 3.5.1),pyaudio 0.2.9。

于 2016-02-14T11:01:05.450 回答
21

您是否打算从麦克风中获取音频或流式传输?无论哪种情况, 可以使用声音设备。

您可以使用安装 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"

这是输出:Python 2.7.9(默认,2014 年 12 月 10 日,12:24:55)[MSC v.1500 32 位(英特尔)] 在 win32 上键入“copyright”、“credits”或“license()”更多信息。=================================重新开始================= ==

录制音频
音频录制完成,播放音频
播放音频完成

于 2016-02-19T20:00:14.257 回答
4

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

你可以从 PyPI获取pysox 包。

于 2016-02-14T10:35:36.150 回答
3

如果要求是Jack,那么您可能想要使用PyJack,它是 Jack 的 Python 绑定。

此外,源代码有一个您想要做的示例,即捕获音频。查看文件capture.py

您必须考虑到避免错过一个块,您必须jack.process500 *(buffer_size/sample_rate)毫秒调用一次。 当您错过音频块(和)jack.process时抛出异常。jack.InputSyncErrorjack.OutputSyncError

于 2016-02-19T01:55:44.170 回答