-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathAudiobook.py
42 lines (38 loc) · 1.13 KB
/
Audiobook.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
import pyttsx3
import speech_recognition as sr
import PyPDF2
def takecommand():
r = sr.Recognizer()
with sr.Microphone() as source:
print('listening...')
r.pause_threshold = 1
r.energy_threshold = 250
audio = r.listen(source, 0 ,5)
try:
print('understanding..')
query = r.recognize_google(audio , language= 'en-in')
print(f"you said: {query}\n")
except Exception as e:
print('say that again')
return "none"
return query
query = takecommand().lower()
engine = pyttsx3.init("sapi5")
voices = engine.getProperty('voices')
engine.setProperty("voice", voices[0].id)
engine.setProperty('rate', 170)
def speak(audio):
engine.say(audio)
engine.runAndWait()
def audioBook(query):
if "read" in query:
query = query.replace("Robo","")
query = query.replace("read","")
query = query.replace("robo read","")
book = open('ROBO.pdf', 'rb')
pdfReader = PyPDF2.PdfFileReader(book)
pages = pdfReader.numPages
print(pages)
pg = pdfReader.getPage(2)
text = pg.extractText()
speak(text)