Я сделал что-то подобное, но использовал python-sounddevice . Вот мой репо
EDIT:
Вот конкретный класс записи звука для уточнения
import threading
import queue
import numpy
import sounddevice as sd
import soundfile as sf
class AudioRecorder():
def __init__(self):
self.open = True
self.file_name = 'name_of_file.wav'
self.channels = 1
self.q = queue.Queue()
# Get samplerate
device_info = sd.query_devices(2, 'input')
self.samplerate = int(device_info['default_samplerate'])
def callback(self, indata, frames, time, status):
# This is called (from a separate thread) for each audio block.
if status:
print(status, file=sys.stderr)
self.q.put(indata.copy())
def record(self):
with sf.SoundFile(self.file_name, mode='x', samplerate=self.samplerate, channels=self.channels) as file:
with sd.InputStream(samplerate=self.samplerate, channels=self.channels, callback=self.callback):
while(self.open == True):
file.write(self.q.get())
РЕДАКТИРОВАТЬ 2: Код представляет собой класс Python, который создает аудиофайл с использованием микрофона I2S, аналогично изображению, показанному в вопросе. Хотя значение self.open
равно true, sounddevice запишет аудиоданные в очередь (def callback
), а затем запишет данные в файл. Все, что вам нужно сделать, это переключить self.open
, чтобы начать и остановить запись.