使用Python读取输入声音信号

时间:2016-02-11 16:22:20

标签: python python-2.7 audio soundcard

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

处理和后续步骤很清楚。我迷失了只是从程序中获取信号。 渠道数量无关紧要,一个就足够了。我不会播放声音,因此声卡上不需要ASIO。

我的问题是:如何从Python中捕获Jack音频? (如果有一个包,有很好的文档和利基示例,那将会很棒。)。

4 个答案:

答案 0 :(得分:31)

你试过pyaudio吗? 安装:python -m pip install pyaudio
记录示例,来自官方网站:

    """PyAudio example: Record a few seconds of audio and save to a WAVE file."""

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。

答案 1 :(得分:14)

您是打算从麦克风中获取音频还是流媒体音频? 无论哪种情况,都可以使用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"
  

这是输出:   win32上的Python 2.7.9(默认,2014年12月10日,12:24:55)[MSC v.1500 32位(英特尔)]   输入" copyright"," credit"或" license()"欲获得更多信息。   ================================ RESTART ================= ==

     
    

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

  

答案 2 :(得分:3)

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

您可以从PyPI获得pysox package

答案 3 :(得分:2)

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

此外,源代码还有一个示例,表示您要执行的操作,即捕获音频。请参阅文件capture.py

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