Building a Customized
Personal Assistant with Python
PyCon JP 2017
2017.09.08 (Fri) Room 201
Iskandar Setiadi
#pyconjp_201
data:image/s3,"s3://crabby-images/afcd5/afcd5911706e56d8263db4b03e314adb387945bb" alt=""
data:image/s3,"s3://crabby-images/78e45/78e45933a9d201bc41600076d86b9c5556e49a24" alt=""
Iskandar Setiadi
Github: freedomofkeima
Personal Website: https://freedomofkeima.com
Software Engineer at HDE, Inc. - Shibuya, Japan
From Jakarta, Indonesia
Graduated from Institut Teknologi Bandung (Indonesia) 2 years ago
On the Map: Indonesia
data:image/s3,"s3://crabby-images/d9d6b/d9d6bb9f23bcb0b5431ee803dab76d381f80908c" alt=""
Why Python?
Started using Python ~3 years ago from an internship in HDE, Inc.
Python is very easy to learn!
The community is nice and friendly :)
data:image/s3,"s3://crabby-images/c0659/c06597487260986d07a8cf54760bafa0080ccaec" alt=""
Prologue
data:image/s3,"s3://crabby-images/13555/1355521bafcb58a8a37174df4530a3d64bc6e6c5" alt=""
data:image/s3,"s3://crabby-images/3d9e5/3d9e55d0156d3b29e739fdffa95fb3a380710339" alt=""
data:image/s3,"s3://crabby-images/9261b/9261bf7bdeaf2daafe7a3486e15f4e9a66eed006" alt=""
data:image/s3,"s3://crabby-images/64333/6433399651b10a4a91c2defc48fee5fcbae183db" alt=""
data:image/s3,"s3://crabby-images/014e6/014e607a8f5b8f226ad67186922bbee86b3b9a3c" alt=""
Maid-chan Overview
data:image/s3,"s3://crabby-images/48888/48888da5cee9aad869feb2a77966c43a946b82ce" alt=""
Why Facebook Messenger?
-
Multi-platforms
Our bots can be accessed everywhere without developing own client-side interface.
-
Huge number of users
Facebook has more than 1 billion of users, which allows us to share our bots with our friends easily.
Deep Learning for Images
Deep Learning Drawbacks
Speed & Initial Setup
Deep Learning requires a lot of dependencies, such as Caffee, Torch, CUDA backend (GPU), etc. It also takes several minutes to generate result from a model, which makes it not usable with mobile devices.
data:image/s3,"s3://crabby-images/90ca0/90ca01c52825b83166108bc54d4e1cef6966b2ad" alt=""
Primitive: Configure Once, Execute Everywhere
def create_primitive_image(image_path, filename): for i in xrange(0, 3): # Generate 3 different images output_path = os.path.join(image_path, "output{}.png".format(i)) args = [ 'primitive', '-i', # input file os.path.join(image_path, filename), '-o', # output file output_path, '-n', # number of iteration '175' ] # Execute p = subprocess.Popen(args, stdout=subprocess.PIPE, shell=False) (output, err) = p.communicate() if err: logging.error(err) return generate_gif_file_from_primitive(image_path, filename)
Showcase
data:image/s3,"s3://crabby-images/def25/def2528fdc2e7d9238f9a490c38ad074f1b8a763" alt=""
data:image/s3,"s3://crabby-images/a01eb/a01eb0912c9b6dc04d24593376d41ef595eba73e" alt=""
data:image/s3,"s3://crabby-images/59c05/59c05075ec03f92134f441c87ea7c9d2745aeb27" alt=""
Daily Lesson
Learning Basic Japanese
data:image/s3,"s3://crabby-images/abbb7/abbb704684dfe9cb48aedb2a964ef6f2e1a49b3e" alt=""
data:image/s3,"s3://crabby-images/e0323/e03235efaf2cb70c05095d4ef54a8476d0c0c538" alt=""
data:image/s3,"s3://crabby-images/1066d/1066dd9032f9f1f14c96f95a747d05f4f0ce53a0" alt=""
Step 2: Retrieve the Data
Python csv module to help!
with open(filename, 'rb') as fobj: reader = csv.reader(fobj, delimiter=',', encoding='utf-8') ... # get random Kanji & Vocabulary based on level choice here
Step 3: Create a Generic Daily Scheduler
while True: current_mt = int(time.time()) metadata = redis_client.get_schedules() if metadata["next_mt"] < current_mt: metadata["kanji_n4"] = get_random_kanji(level=4) ... # Store any other daily information metadata["next_mt"] += 86400 # every 1 day redis_client.set_schedules(metadata)
Subscribe
data:image/s3,"s3://crabby-images/48058/480589e120f23e78302afa13e7bb32d022ba9486" alt=""
Showcase
data:image/s3,"s3://crabby-images/a598e/a598e8c9fe2e7748e2b655da798d4b9c75c3ac0e" alt=""
Automatic Translation
Language Preference
data:image/s3,"s3://crabby-images/f5748/f5748baa294fbea8a2a79edf645c4768167117db" alt=""
Examples
data:image/s3,"s3://crabby-images/eaedb/eaedb7f7314159ca59f2caf1cc3d0fa93da1abd9" alt=""
Examples
data:image/s3,"s3://crabby-images/3a447/3a447f62acdeb7897390f4e14900b37e44cec142" alt=""
shlex - Simple Lexical Analysis
import shlex try: elements = shlex.split(query.encode('utf-8')) except: elements = [query.encode('utf-8')] # Input : Translate "I am going to Pycon" to 日本語 # Output : ['Translate', 'I am going to Pycon', 'to', '日本語']
trans-shell to Google Translate
... # Use trans online language detection if not source_language_key: source_language_key = get_trans_language_prediction(source_text) # "trans -id {text}" handling if not target_language_key: target_language_key = Constants.TRANSLATION_MAP[source_language_key] args = ["trans", "-b", "{}:{}".format(source_language_key, target_language_key), source_text] p = subprocess.Popen(args, stdout=subprocess.PIPE, shell=False) (output, _) = p.communicate() return output
Train Status
Train Accident
data:image/s3,"s3://crabby-images/1d3e7/1d3e7e03ff2de74a5d216a883fd3d6aee45d4462" alt=""
data:image/s3,"s3://crabby-images/4b105/4b10595464afa16d8ef15d843a53adaa777fb235" alt=""
requests + BeautifulSoup + Google Translate
import requests from bs4 import BeautifulSoup # Retrieve page r = requests.get("https://transit.yahoo.co.jp/traininfo/area/4/") # Yahoo Page soup = BeautifulSoup(r.content, "html.parser") soup_attrs = soup.select('div.trouble table tr td')
Chatbot
Showcase
data:image/s3,"s3://crabby-images/59586/5958625e105c8e1160cb9ff9af10b991f0098c14" alt=""
Showcase
data:image/s3,"s3://crabby-images/c11f1/c11f1b3d1338cd5a4d2cc14172edfd128806975b" alt=""
Showcase
data:image/s3,"s3://crabby-images/39777/39777fb62401c0fa051ca19fcd24d3728ad612b7" alt=""
Showcase
data:image/s3,"s3://crabby-images/36e8d/36e8d963b74318df4a4059dd247a41366529235e" alt=""
ChatterBot
$ pip install chatterbot
from chatterbot import ChatBot chatbot = ChatBot( 'Ron Obvious', trainer='chatterbot.trainers.ChatterBotCorpusTrainer' ) # Train based on the english corpus chatbot.train("chatterbot.corpus.english") # Get a response to an input statement chatbot.get_response("Hello, how are you today?") # Response: "I am doing well."
Custom Corpus
self.chatbot = ChatBot( 'Maid-chan', trainer='chatterbot.trainers.ChatterBotCorpusTrainer', # Can also be trained with Twitter or Ubuntu dialog corpus output_adapter="chatterbot.output.OutputFormatAdapter", # Output can be integrated with other framework (MS Bot) output_format='text', storage_adapter="chatterbot.storage.MongoDatabaseAdapter" # Can be stored in JSON file, MongoDB, or even SQL Alchemy ) self.chatbot.train( "chatterbot.corpus.indonesia.conversations", "chatterbot.corpus.indonesia.greetings", "chatterbot.corpus.english.conversations", "chatterbot.corpus.english.greetings", "chatterbot.corpus.maidcorpus" # Train from a custom corpus )
RSS Aggregator
Examples
data:image/s3,"s3://crabby-images/dc9c6/dc9c6f0f3b27130f491659ae1733095270eb99a1" alt=""
Examples
data:image/s3,"s3://crabby-images/70641/70641587eaf70cbcd9620d8c0323f0054efec66d" alt=""
feedparser
$ pip install feedparser # https://github.com/kurtmckee/feedparser
import feedparser response = feedparser.parse(url) if 'bozo_exception' in response: # invalid response, not a valid RSS return False for entry in response.get("entries", {}): title = entry.get("title") ...
Bonus: Daily Greetings
data:image/s3,"s3://crabby-images/8a260/8a260a0b798be0fb64c98a243079627fcb29af7d" alt=""
Daily Greetings
Make your bot more fun!
With generic scheduler (daily lesson), Maid-chan is equipped with daily greetings feature.
* * *
FB Messenger Bot: Configure
data:image/s3,"s3://crabby-images/d2345/d23457beb3aab024ba311fe3f358702e211bf4c9" alt=""
Documentation: https://developers.facebook.com/docs/messenger-platform/getting-started
Caveat & Lesson Learned
- Facebook has 20 seconds timeout
- Facebook will keep sending the message until a response is given
- Timezone handling for better user experience
- Friends can be added as Application Tester (pre-release)
- Users are prone to make mistakes
- Don't trust user input for learning (Chatbot)
Infinite Possibilities
data:image/s3,"s3://crabby-images/751b2/751b201b477f600c7e8dbe86d6768e62794b5f02" alt=""
Optimus Prime Bot (Example: Location x Yelp) https://github.com/hungtraan/FacebookBot
Infinite Possibilities (General)
- Location-aware features: Recommendation list, weather forecast, etc
- IoT integration: Surveillance camera, air conditioner, etc
- Better NLP: Wit.ai (Facebook), IBM Watson, Google Cloud Speech, LUIS (Azure), Amazon Lex, etc
Start building your own bot!
Closing
Project available at https://github.com/freedomofkeima/messenger-maid-chan
data:image/s3,"s3://crabby-images/a97ad/a97ad14fca67b5453610c41d1e935495a51fbe72" alt=""
Presentation slide available at https://freedomofkeima.com/pyconjp2017/
Thank you!
data:image/s3,"s3://crabby-images/41d6d/41d6d3797474461223d738806cab3973f7986a62" alt="Profile Picture"
* * *