-
Notifications
You must be signed in to change notification settings - Fork 0
/
speechtool.py
100 lines (88 loc) · 2.73 KB
/
speechtool.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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
# oreo
"""
✘ Commands Available -
• `{i}tts` `LanguageCode <reply to a message>`
• `{i}tts` `LangaugeCode | text to speak`
• `{i}stt` `<reply to audio file>`
`Convert Speech to Text...`
`Note - Sometimes Not 100% Accurate`
"""
import os
import subprocess
from datetime import datetime
import speech_recognition as sr
from gtts import gTTS
from . import *
reco = sr.Recognizer()
@oreo_cmd(
pattern="tts ?(.*)",
)
async def _(event):
input_str = event.pattern_match.group(1)
start = datetime.now()
if event.reply_to_msg_id:
previous_message = await event.get_reply_message()
text = previous_message.message
lan = input_str
elif "|" in input_str:
lan, text = input_str.split("|")
else:
await event.eor("Invalid Syntax. Module stopping.")
return
text = text.strip()
lan = lan.strip()
if not os.path.isdir("downloads/"):
os.makedirs("downloads/")
required_file_name = "downloads/voice.ogg"
try:
tts = gTTS(text, lang=lan)
tts.save(required_file_name)
command_to_execute = [
"ffmpeg",
"-i",
required_file_name,
"-map",
"0:a",
"-codec:a",
"libopus",
"-b:a",
"100k",
"-vbr",
"on",
required_file_name + ".opus",
]
try:
subprocess.check_output(command_to_execute, stderr=subprocess.STDOUT)
except (subprocess.CalledProcessError, NameError, FileNotFoundError) as exc:
await event.eor(str(exc))
else:
os.remove(required_file_name)
required_file_name = required_file_name + ".opus"
end = datetime.now()
ms = (end - start).seconds
await event.reply(
file=required_file_name,
)
os.remove(required_file_name)
await eod(event, "Processed {} ({}) in {} seconds!".format(text[0:97], lan, ms))
except Exception as e:
await event.eor(str(e))
@oreo_cmd(pattern="stt")
async def speec_(e):
reply = await e.get_reply_message()
if not (reply and reply.media):
return await eod(e, "`Reply to Audio-File..`")
# Not Hard Checking File Types
re = await reply.download_media()
fn = re + ".wav"
await bash(f'ffmpeg -i "{re}" -vn "{fn}"')
with sr.AudioFile(fn) as source:
audio = reco.record(source)
try:
text = reco.recognize_google(audio, language="en-IN")
except Exception as er:
return await e.eor(str(er))
out = "**Extracted Text :**\n `" + text + "`"
await e.eor(out)
os.remove(fn)
os.remove(re)