forked from mikeyy/nonoCAPTCHA
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_speech.py
53 lines (42 loc) · 1.44 KB
/
test_speech.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
import asyncio
import os
from pydub import AudioSegment, playback
from nonocaptcha.base import settings
from nonocaptcha.util import threaded
from nonocaptcha.speech import Amazon, Azure, Sphinx, DeepSpeech
speech_service = settings["speech"]["service"]
audio_dir = "audio_files"
post_play_audio = True
@threaded
def play_audio(mp3_filename):
playback.play(AudioSegment.from_mp3(mp3_filename))
async def solve(service, audio_file):
answer = None
service = service.lower()
if service in ["azure", "pocketsphinx", "deepspeech"]:
if service == "azure":
speech = Azure()
elif service == "pocketsphinx":
speech = Sphinx()
else:
speech = DeepSpeech()
answer = await speech.get_text(audio_file)
else:
speech = Amazon()
answer = await speech.get_text(audio_file)
if answer:
print(f"audio file: {audio_file}")
print(f"{service}'s best guess: {answer}")
else:
print(f"{service}'s failed to decipher: {audio_file}")
if post_play_audio:
await play_audio(audio_file)
print("--------"*15)
async def main():
for dirs, subdirs, files in os.walk(audio_dir):
for fname in files:
ext = os.path.splitext(fname)[-1].lower()
if ext == ".mp3":
fpath = os.path.join(audio_dir, fname)
await solve(speech_service, fpath)
asyncio.get_event_loop().run_until_complete(main())