2021-02-18 10:16:30 +01:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
from vosk import Model, KaldiRecognizer, SetLogLevel
|
|
|
|
import sys
|
|
|
|
import os
|
|
|
|
import wave
|
|
|
|
|
|
|
|
SetLogLevel(0)
|
|
|
|
if not os.path.exists("models/fr"):
|
|
|
|
print ("Please download the model from https://alphacephei.com/vosk/models and unpack as 'models' in the current folder.")
|
|
|
|
exit (1)
|
|
|
|
|
2021-03-23 12:13:23 +01:00
|
|
|
|
2021-02-18 10:16:30 +01:00
|
|
|
wf = wave.open(sys.argv[1], "rb")
|
|
|
|
if wf.getnchannels() != 1 or wf.getsampwidth() != 2 or wf.getcomptype() != "NONE":
|
|
|
|
print ("Audio file must be WAV format mono PCM.")
|
|
|
|
exit (1)
|
|
|
|
|
|
|
|
model = Model("models/fr")
|
|
|
|
rec = KaldiRecognizer(model, wf.getframerate())
|
|
|
|
|
|
|
|
while True:
|
|
|
|
data = wf.readframes(4000)
|
|
|
|
if len(data) == 0:
|
|
|
|
break
|
|
|
|
if rec.AcceptWaveform(data):
|
|
|
|
print(rec.Result())
|
|
|
|
|
|
|
|
print(rec.FinalResult())
|