-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSource code
121 lines (95 loc) · 3.24 KB
/
Source code
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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#!/usr/bin/env python
# coding: utf-8
# In[9]:
import pyttsx3
import datetime
import speech_recognition as sr
import wikipedia
import requests
import json
import webbrowser
import os
import pywhatkit as kit
# In[10]:
engine = pyttsx3.init('sapi5')
# In[12]:
voices = engine.getProperty('voices')
#print('voices')
engine.setProperty('voice',voices[0].id)
print(voices[0].id)
author = 'Jarvis'
def speak(audio):
engine.say(audio)
engine.runAndWait()
def wishme():
hour = int(datetime.datetime.now().hour)
if hour >= 0 and hour < 12:
speak(f"Good Morning {author}")
elif hour >= 12 and hour < 18:
speak(f"Good Afternoon {author}")
else:
speak(f"Good Evening {author}")
speak(f'Hello {author}, I am jarvis please tell me how can i assist you?')
#Take input as voice and return in string
def takecommand():
r = sr.Recognizer()
with sr.Microphone() as source:
print('listening..')
r.pause_threshold = 1.5
audio = r.listen(source)
try:
print('recognizing...')
query = r.recognize_google(audio, language ='en-in')
print(f'{author}: {query}\n')
except Exception as e:
print(f'Sorry,{author} say that again!')
return 'none'
return query
if __name__ == '__main__':
#speak(f'Welcome {author}, I am Jarvis')
wishme()
#takecommand()
if 1:
query = takecommand().lower()
if 'wikipedia' and 'who' in query:
speak('Searching wikpedia..')
query = query.replace('wikipedia','')
results = wikipedia.summary(query, sentences = 2)
print(results)
speak('According to wikipedia:')
speak(results)
elif 'news' in query:
speak('News headlines')
query = query.replace('news','')
url = "https://newsapi.org/v2/top-headlines?country=in&apiKey=29b6d402e2984bacad3370be922e436a"
news = requests.get(url).text
news = json.loads(news)
art = news['articles']
ncount = 0
for article in art:
print(article['title'])
speak(article['title'])
print(article['description'])
speak(article['description'])
ncount=ncount+1
if ncount == 2:
break
speak('towards the next news')
elif 'open google' in query:
webbrowser.open('www.google.com')
elif 'open youtube' in query:
webbrowser.open('www.youtube.com')
elif 'search browser' in query:
speak("What should i search?")
um = takecommand().lower()
webbrowser.open(f"{um}")
elif 'ip address' in query:
ip = requests.get('http://api.ipify.org').text
print(f'Your ip address is {ip}')
speak(f'Your ip address is {ip}')
elif "open command prompt" in query:
os.system("start cmd")
elif "play on youtube" in query:
speak("What should i play?")
cm = takecommand().lower()
kit.playonyt(f"{cm}")