我需要从一个插孔连接的麦克风获得声音信号,并使用这些数据在Python中进行即时处理。
处理和后续步骤都很清楚。 我只是在接收程序发出的信号时不知所措。 渠道多少无关紧要,一个就够了。 我不打算回放声音,所以应该不需要ASIO在声卡上。
我的问题是:如何从Python中捕获Jack音频? (如果有一个包,有很好的文档和利基示例就太好了:-)。
你试过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和pyaudio 0.2.9中的Python 2.7.11(和3.5.1)。
您打算从麦克风获取片段或流式音频吗? 无论哪种情况,都可以采用发声装置。
您可以使用pip install sounddevice--user
安装python模块
有关API的详细信息,请参考官方网站。
sounddevice将从您的笔记本电脑麦克风(标准音频输入)录制音频,并在扬声器或耳机上播放(标准音频输出)。 您可以使用sound对象进行进一步处理。
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(默认值,Dec10 2014,12:24:55)[MSC v.1500 32位(Intel)],键入“版权”,“信用”或“许可()”以获取更多信息。 =======================================================================================================
录制音频
音频录制完成,播放音频
播放音频完成
我会考虑使用pysox,即libsox的python绑定。
您可以从PyPI获得pysox包。