Creating a Virtual Assistant using Python
Virtual assistants are Artificial Intelligent based programs. They are a smart computer program that understands human natural languages through voice commands or text and performs tasks for the user. This article will guide you through the process of creating your own voice assistant through the use of a Python library. <!--more--> For this tutorial, I will be writing the code on Pycharm IDE by Jetbrains.
PyCharm is an integrated development platform for computer programming, with an emphasis on the Python programming language. JetBrains, a Czech company, built it. Click here to download Pycharm.
After downloading and installing Pycharm, launch the application and click on the file menu, then select new project. A pop-up message will ask you for your project's name. Kindly give it a desired name, but for this article, we will give our project the title “vitualBot”.
The project will load. Once loading is complete, clear the automated content in the "main.py" file to have a clean screen for your code.
What does a virtual assistant do?
- It listens for your command.
- It responds to your command with either a success or failure response.
For this article, 3 Python libraries will be used, they include:
- Python Speech Recognition: Recognition speech is the act of translating spoken words into text. Python supports many speech recognition engines such as Google Speech Engine, Microsoft Bing Voice Recognition, and many others.
This library translates audio signal into a computer-readable format. Typically, this is a spectrogram. It's a three-dimensional graph with time on the x-axis, frequency on the y-axis, and color representing strength.
To use the Python speech recognition library, click this link and you should see the page as shown in the image below.
Copy the text circled in red.
Paste what you copied in the terminal and click enter. The package will be installed. Once this first package is installed, we need the second package, which is:
- Python Text To Speech v3 (Pyttsx3): This library is a text-to-speech conversion library in Python. This library works offline and it is also compatible with Python version 2 and 3.
This package can be downloaded here. Copy the command found on the website and paste it in the terminal just as you did with the first library.
Once you have successfully installed the second package, we will continue to install the third package.
- Python Audio (PyAudio): PyAudio allows you to quickly play and record audio on a number of devices using Python. Download the package here. Install the package using the steps used in 1 above.
Note
For Linux users, you might encounter an error when installing Pyaudio.
Follow the steps to fix the error:
- Install portaudio modules using this command:
sudo apt-get install libasound-dev
-
Download the portaudio archive from this Link
-
Unzip the archive using:
tar -zxvf [filename portaudio.tgz]
- Enter the directory of the unzipped portaudio file, then run:
./configure && make
- Once that is successful, install it by using this command:
sudo make install
- Finally, install pyaudio:
pip install pyaudio
We have successfully installed the three libraries.
Now, let's give our Virtual assistant life!!!
# import the library needed for the virtual assistant
import speech_recognition as assistance
import pyttsx3
# now, let us obtain voice input from the microphone
listener = assistance.Recognizer()
# the next line is to initiate the pttsx3 library
engine = pyttsx3.init()
# let's take voice from our microphone and use our microphone as source
with assistance.Microphone() as source:
print("Say something...!")
audio = listener.listen(source)
# recognize your speech using the Google Speech Recognizer
try:
print("I heard you say " + listener.recognize_google(audio))
except assistance.UnknownValueError:
print("Hey, I could not understand what you say")
except assistance.RequestError as e:
print("Request from Google Speech Recognition failed; {0}".format(e))
#the engine will then repeat what you said before performing your command
engine.say(audio)
engine.runAndWait()
There are many things you can achieve with Python libraries.
With the tutorial above, you should be able to dive more into making your virtual assistant smarter.
Thanks for reading.
Happy coding!
Peer Review Contributions by: Peter Kayere