0% found this document useful (0 votes)
124 views

Computer Python Voice Chatbot

The document discusses the development of a chatbot using Python. It describes how the chatbot will use Artificial Intelligence Markup Language (AIML) and Latent Semantic Analysis (LSA) to provide accurate responses to user queries. The source code provided shows the chatbot greeting the user, taking voice commands, searching Wikipedia, and opening websites like YouTube and Google based on the user's request.
Copyright
© © All Rights Reserved
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
124 views

Computer Python Voice Chatbot

The document discusses the development of a chatbot using Python. It describes how the chatbot will use Artificial Intelligence Markup Language (AIML) and Latent Semantic Analysis (LSA) to provide accurate responses to user queries. The source code provided shows the chatbot greeting the user, taking voice commands, searching Wikipedia, and opening websites like YouTube and Google based on the user's request.
Copyright
© © All Rights Reserved
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 25

INTRODUCTION

A chatbot is an automated software program that interacts with humans. A


chatbot is merely a computer program that fundamentally simulates human
conversations. A chatbot that functions through AI and machine learning has an
artificial neural network inspired by the neural nodes of the human brain. Chatbots
are programs that can do talk like human conversations very easily. For example,
Facebook has a machine learning chatbot that creates a platform for companies to
interact with their consumers through the Facebook Messenger application. In
2016, chatbots became too popular on Messenger. By the consequences is noted
that 2016 was the entire year of chatbots. The software industry is mainly oriented
on chatbots. Thousands of chatbots are invented on startups and used by the
businesses to improve their customer service, keeping them hanging by a kind
communication. According to research, nowadays chatbots are used to solve a
number of business tasks across many industries like E-Commerce, Insurance,
Banking, Healthcare, Finance, Legal, Telecom, Logistics, Retail, Auto, Leisure,
Travel, Sports, Entertainment, Media and many others. Thus that was the moment
to look at the chatbots as a new technology in the communication field. Nowadays
various companies are using chatbots to answer quickly and efficiently some
frequented asking questions from their own customers.AIML and LSA are used for
creating chatbots. Artificial Intelligence Markup Language (AIML) and Latent
Semantic Analysis (LSA) are used for developing chatbots, which are used to
define general pattern-based queries. This pattern can also be used to give random
responses for the same query in the chatbot. LSA is a Latent Semantic Analysis
technology in python, which is utilized to discover likenesses between words as
vector representation. So that the unanswered queries by AIML will be viewed as a
reply by LSA.

1
ABSTRACT

A chatbot is a computer software program that conducts a conversation via


auditory or textual methods. This software is used to perform tasks such as quickly
responding to users, informing them, helping to purchase products and providing
better service to customers. Chatbots are programs that work on Artificial
Intelligence (AI) & Machine Learning Platform. Chatbot has become more popular
in business groups right now as it can reduce customer service costs and handles
multiple users at a time. But yet to accomplish many tasks there is a need to make
chatbots as efficient as possible. In this project, we provide the design of a chatbot,
which provides a genuine and accurate answer for any query using Artificial
Intelligence Markup Language (AIML) and Latent Semantic Analysis (LSA) with
python platform.

2
TECHNOLOGY USED

FORNT END:- {PYTHON}


Python is an interpreted high- level and general- purpose programming
language. Python’s design philosophy emphasizes code readability with its notable
use of significant indentation its language constructs and object- oriented approach
aim to help programmers write clear logical code for small and large scale projects.

MODULES NEEDED

Subprocess:- This module is used to get system subprocess details used in


various commands i.e Shutdown, Sleep, etc. This module comes built-in with
Python. 
 WolframAlpha:- It is used to compute expert-level answers using Wolfram’s
algorithms, knowledgebase and AI technology. To install this module type the
below command in the terminal.

Pyttsx3:- 

This module is used for the conversion of text to speech in a program it works
offline. To install this module type the below command in the terminal.pip install
pyttsx3.
 Tkinter:- 

This module is used for building GUI and comes inbuilt with Python. This module
comes built-in with Python. 

3
REQUIREMENTS

HARDWARE REQUIREMENTS:

 RAM:8GB
 ROM:100GB
 PROCESSOR: Intel (R) core(TM) [email protected]

SOFTWARE REQUIREMENTS:

 Operating System: Windows 10pro


 64bit operating system ,64 based processor.

4
EXISTING SYSTEM

A chat boy (also known as talk bot, Bot, chatter box, Artificial
conversational entity) is a computer program which conducts a conversation via
auditory or textual methods. Such programs are every time designed to determine
how a human would behave as a conversational partner, thereby passing the Turing
test.

5
PROPOSED SYSTEM

In this work, we have developed an interactive chatbot using the Flask


framework in python, and the workflow of the proposed framework is shown in
Fig-5.1. User discussion, as a rule, begins with the simple welcome or general
questions. User inquiries are first taken care of by AIML check, to check whether
the entered inquiry is AIML script or not. AIML is characterized by general
inquiries, queries, and welcome which is replied by utilizing AIML formats.Once
the bot-user types in the query in the chatbot, the AIML developed chatbot will
identify the category that contains the query pattern. Here the bot-user is expected
to type in the query in a predefined pattern. Once the query pattern is matched, the
template of the category that contains the response is sent back to the bot-user.

6
def speak(audio):

    engine.say(audio)

    engine.runAndWait()
 

def wishMe():

    hour = int(datetime.datetime.now().hour)

    if hour>= 0 and hour<12:

        speak("Good Morning Sir !")

  

    elif hour>= 12 and hour<18:

        speak("Good Afternoon Sir !")  

  

    else:

        speak("Good Evening Sir !") 

  

    assname =("Jarvis 1 point o")

    speak("I am your Assistant")

    speak(assname)

     

7
 

def username():

    speak("What should i call you sir")

    uname = takeCommand()

    speak("Welcome Mister")

    speak(uname)

    columns = shutil.get_terminal_size().columns

     

    print("#####################".center(columns))

    print("Welcome Mr.", uname.center(columns))

    print("#####################".center(columns))

     

    speak("How can i Help you, Sir")


 

def takeCommand():

     

    r = sr.Recognizer()

     

    with sr.Microphone() as source:

8
         

        print("Listening...")

        r.pause_threshold = 1

        audio = r.listen(source)

  

    try:

        print("Recognizing...")   

        query = r.recognize_google(audio, language ='en-


in')

        print(f"User said: {query}\n")

  

    except Exception as e:

        print(e)   

        print("Unable to Recognize your voice.") 

        return "None"

     

    return query

  

9
def sendEmail(to, content):

    server = smtplib.SMTP('smtp.gmail.com', 587)

    server.ehlo()

    server.starttls()

     

    # Enable low security in gmail

    server.login('your email id', 'your email password')

    server.sendmail('your email id', to, content)

    server.close()
SOURCE CODE

def speak(audio):
engine.say(audio)
engine.runAndWait()
def wishMe():
hour = int(datetime.datetime.now().hour)
if hour>= 0 and hour<12:
speak("Good Morning Sir !")
elif hour>= 12 and hour<18:
speak("Good Afternoon Sir !")
else:
speak("Good Evening Sir !")

10
assname =("Jarvis 1 point o")
speak("I am your Assistant")
speak(assname)
def username():
speak("What should i call you sir")
uname = takeCommand()
speak("Welcome Mister")
speak(uname)
columns = shutil.get_terminal_size().columns
print("#####################".center(columns))
print("Welcome Mr.", uname.center(columns))
print("#####################".center(columns))
speak("How can i Help you, Sir")
def takeCommand():
r = sr.Recognizer()
with sr.Microphone() as source:
print("Listening...")
r.pause_threshold = 1
audio = r.listen(source)
try:
print("Recognizing...")
query = r.recognize_google(audio, language ='en-in')
print(f"User said: {query}\n")
except Exception as e:
print(e)
11
print("Unable to Recognize your voice.")
return "None"
return query
def sendEmail(to, content):
server = smtplib.SMTP('smtp.gmail.com', 587)
server.ehlo()
server.starttls()
# Enable low security in gmail
server.login('your email id', 'your email password')
server.sendmail('your email id', to, content)
server.close()

if __name__ == '__main__':
clear = lambda: os.system('cls')
# This Function will clean any
# command before execution of this python file
clear()
wishMe()
username()
while True:
query = takeCommand().lower()
# All the commands said by user will be
# stored here in 'query' and will be
# converted to lower case for easily
# recognition of command

12
if 'wikipedia' in query:
speak('Searching Wikipedia...')
query = query.replace("wikipedia", "")
results = wikipedia.summary(query, sentences = 3)
speak("According to Wikipedia")
print(results)
speak(results)
elif 'open youtube' in query:
speak("Here you go to Youtube\n")
webbrowser.open("youtube.com")
elif 'open google' in query:
speak("Here you go to Google\n")
webbrowser.open("google.com")
elif 'open stackoverflow' in query:
speak("Here you go to Stack Over flow.Happy coding")
webbrowser.open("stackoverflow.com")
elif 'play music' in query or "play song" in query:
speak("Here you go with music")
# music_dir = "G:\\Song"
music_dir = "C:\\Users\\GAURAV\\Music"
songs = os.listdir(music_dir)
print(songs)
random = os.startfile(os.path.join(music_dir, songs[1]))
elif 'the time' in query:
strTime = datetime.datetime.now().strftime("% H:% M:% S")
13
speak(f"Sir, the time is {strTime}")
elif 'open opera' in query:
codePath = r"C:\\Users\\GAURAV\\AppData\\Local\\Programs\\Opera\\
launcher.exe"
os.startfile(codePath)
elif 'email to gaurav' in query:
try:
speak("What should I say?")
content = takeCommand()
to = "Receiver email address"
sendEmail(to, content)
speak("Email has been sent !")
except Exception as e:
print(e)
speak("I am not able to send this email")
elif 'send a mail' in query:
try:
speak("What should I say?")
content = takeCommand()
speak("whome should i send")
to = input()
sendEmail(to, content)
speak("Email has been sent !")
except Exception as e:
print(e)

14
speak("I am not able to send this email")
elif 'how are you' in query:
speak("I am fine, Thank you")
speak("How are you, Sir")
elif 'fine' in query or "good" in query:
speak("It's good to know that your fine")
elif "change my name to" in query:
query = query.replace("change my name to", "")
assname = query
elif "change name" in query:

speak("What would you like to call me, Sir ")

assname = takeCommand()
speak("Thanks for naming me")
elif "what's your name" in query or "What is your name" in query:
speak("My friends call me")
speak(assname)
print("My friends call me", assname)
elif 'exit' in query:
speak("Thanks for giving me your time")
exit()
elif "who made you" in query or "who created you" in query:
speak("I have been created by Gaurav.")
elif 'joke' in query:
15
speak(pyjokes.get_joke())
elif "calculate" in query:
app_id = "Wolframalpha api id"
client = wolframalpha.Client(app_id)
indx = query.lower().split().index('calculate')
query = query.split()[indx + 1:]
res = client.query(' '.join(query))
answer = next(res.results).text
print("The answer is " + answer)
speak("The answer is " + answer)
elif 'search' in query or 'play' in query:
query = query.replace("search", "")
query = query.replace("play", "")
webbrowser.open(query)
elif "who i am" in query:
speak("If you talk then definitely your human.")
elif "why you came to world" in query:
speak("Thanks to Gaurav. further It's a secret")
elif 'power point presentation' in query:
speak("opening Power Point presentation")
power = r"C:\\Users\\GAURAV\\Desktop\\Minor Project\\Presentation\\
Voice Assistant.pptx"
os.startfile(power)
elif 'is love' in query:
speak("It is 7th sense that destroy all other senses")

16
elif "who are you" in query:
speak("I am your virtual assistant created by Gaurav")
elif 'reason for you' in query:
speak("I was created as a Minor project by Mister Gaurav ")
elif 'change background' in query:
ctypes.windll.user32.SystemParametersInfoW(20,
0,
"Location of wallpaper",
0)
speak("Background changed successfully")
elif 'open bluestack' in query:
appli = r"C:\\ProgramData\\BlueStacks\\Client\\Bluestacks.exe"
os.startfile(appli)
elif 'news' in query:
try:
jsonObj = urlopen('''https://newsapi.org / v1 / articles?source = the-times-
of-india&sortBy = top&apiKey =\\times of India Api key\\''')
data = json.load(jsonObj)
i=1
speak('here are some top news from the times of india')
print('''=============== TIMES OF INDIA ============'''+ '\n')
for item in data['articles']:
print(str(i) + '. ' + item['title'] + '\n')
print(item['description'] + '\n')
speak(str(i) + '. ' + item['title'] + '\n')

17
i += 1
except Exception as e:
print(str(e))
elif 'lock window' in query:
speak("locking the device")
ctypes.windll.user32.LockWorkStation()
elif 'shutdown system' in query:
speak("Hold On a Sec ! Your system is on its way to shut down")
subprocess.call('shutdown / p /f')
elif 'empty recycle bin' in query:
winshell.recycle_bin().empty(confirm = False, show_progress = False,
sound = True)
speak("Recycle Bin Recycled")
elif "don't listen" in query or "stop listening" in query:
speak("for how much time you want to stop jarvis from listening
commands")
a = int(takeCommand())
time.sleep(a)
print(a)
elif "where is" in query:
query = query.replace("where is", "")
location = query
speak("User asked to Locate")
speak(location)
webbrowser.open("https://www.google.nl / maps / place/" + location + "")

18
elif "camera" in query or "take a photo" in query:
ec.capture(0, "Jarvis Camera ", "img.jpg")
elif "restart" in query:
subprocess.call(["shutdown", "/r"])
elif "hibernate" in query or "sleep" in query:
speak("Hibernating")
subprocess.call("shutdown / h")
elif "log off" in query or "sign out" in query:
speak("Make sure all the application are closed before sign-out")
time.sleep(5)
subprocess.call(["shutdown", "/l"])
elif "write a note" in query:
speak("What should i write, sir")
note = takeCommand()
file = open('jarvis.txt', 'w')
speak("Sir, Should i include date and time")
snfm = takeCommand()
if 'yes' in snfm or 'sure' in snfm:
strTime = datetime.datetime.now().strftime("% H:% M:% S")
file.write(strTime)
file.write(" :- ")
file.write(note)
else:
file.write(note)
elif "show note" in query:
19
speak("Showing Notes")
file = open("jarvis.txt", "r")
print(file.read())
speak(file.read(6))
elif "update assistant" in query:
speak("After downloading file please replace this file with the downloaded
one")
url = '# url after uploading file'
r = requests.get(url, stream = True)
with open("Voice.py", "wb") as Pypdf:
total_length = int(r.headers.get('content-length'))
for ch in progress.bar(r.iter_content(chunk_size = 2391975),
expected_size =(total_length / 1024) + 1):
if ch:
Pypdf.write(ch)
# NPPR9-FWDCX-D2C8J-H872K-2YT43
elif "jarvis" in query:
wishMe()
speak("Jarvis 1 point o in your service Mister")
speak(assname)
elif "weather" in query:
# Google Open weather website
# to get API of Open weather
api_key = "Api key"
base_url = "http://api.openweathermap.org / data / 2.5 / weather?"

20
speak(" City name ")
print("City name : ")
city_name = takeCommand()
complete_url = base_url + "appid =" + api_key + "&q =" + city_name
response = requests.get(complete_url)
x = response.json()
if x["code"] != "404":
y = x["main"]
current_temperature = y["temp"]
current_pressure = y["pressure"]
current_humidiy = y["humidity"]
z = x["weather"]
weather_description = z[0]["description"]
print(" Temperature (in kelvin unit) = " +str(current_temperature)+"\n
atmospheric pressure (in hPa unit) ="+str(current_pressure) +"\n humidity (in
percentage) = " +str(current_humidiy) +"\n description = "
+str(weather_description))
else:
speak(" City Not Found ")
elif "send message " in query:
# You need to create an account on Twilio to use this service
account_sid = 'Account Sid key'
auth_token = 'Auth token'
client = Client(account_sid, auth_token)
message = client.messages \
.create(

21
body = takeCommand(),
from_='Sender No',
to ='Receiver No'
)
print(message.sid)
elif "wikipedia" in query:
webbrowser.open("wikipedia.com")
elif "Good Morning" in query:
speak("A warm" +query)
speak("How are you Mister")
speak(assname)
# most asked question from google Assistant
elif "will you be my gf" in query or "will you be my bf" in query:
speak("I'm not sure about, may be you should give me some time")
elif "how are you" in query:
speak("I'm fine, glad you me that")
elif "i love you" in query:
speak("It's hard to understand")
elif "what is" in query or "who is" in query:
# Use the same API key
# that we have generated earlier
client = wolframalpha.Client("API_ID")
res = client.query(query)
try:
print (next(res.results).text)
22
speak (next(res.results).text)
except StopIteration:
print ("No results")
# elif "" in query:
# Command go here
# For adding more commands

OUTPUT

Listening…
Recognizing…
User said: Gaurav
#####################
Welcome Mr. Gaurav
#####################
Listening…
Recognizing…
User said: yes
(‘As the history majors among you here today know all too well, when people in
power invent their own facts and attack those who question them, it can mark the
beginning of the end of a free society. That is not hyperbole. It is what
authoritarian regimes throughout history have done. They attempt to control
reality. Not just our laws and our rights and our budgets, but our thoughts and
beliefs.’, ‘Hillary Clinton’)
Listening…
Recognizing…
User said: Gaurav in Wikipedia

23
Gaurav is an Indian and Nepalese male name. The name literally means pride.
== Notable people named Gaurav ==
Gaurav S Bajaj, Indian television actor
Gaurav Bhatt, Indian Music Director, singer, songwriter.
Listening…
Recognizing…
User said: open YouTube
Listening…
Recognizing…
Unable to Recognizing your voice.
Listening…
Recognizing…
User said: exit

CONCLUSION

In this project, we have introduced a chatbot that is able to interact with


users. This chatbot can answer queries in the textual user input. For this purpose,
AIML with program-o has been used. The chatbot can answer only those questions
which he has the answer in its AIML dataset. So, to increase the knowledge of the
chatbot, we can add the APIs of Wikipedia, Weather Forecasting Department,
Sports, News, Government and a lot more. In such cases, the user will be able to
talk and interact with the chatbot in any kind of domain. Using APIs like Weather,
Sports, News and Government Services, the chatbot will be able to answer the
questions outside of its dataset and which are currently happening in the real
world. The next step towards building chatbots involves helping people to facilitate

24
their work and interact with computers using natural language or using their set of
rules. Future Such chatbots, backed by machine-learning technology, will be able
to remember past conversations and learn from them to answer new ones. The
challenge would be conversing with the various multiple bot users and multiple
users. As future work, we can make a chatbot that is based on AIML and LSA.
This technology will enable a client to interact with a chatbot in a more natural
fashion. We can enhance the discussion by including and changing patterns and
templates for general client queries using AIML and the right response are given
more often than LSA.

BIBILOGRAHY

www.Python.Org

www.wikipedia.com

www.Tuitorialspoint.com

www.blogspot.comn

25

You might also like