ひとこと
pythonの勉強を始めようと思い、手始めにSlackbotを使ったbotを作成。
簡単な会話(特定の言葉に返事を返す)機能と天気・遅延情報を教えてくれる機能を追加。
その時のメモ。
準備
python環境の構築
Pythonをインストールします。
Anacondaを使うとPythonの環境を構築してくれるので便利です。
ので、今回はAnacondaを使った環境構築方法を紹介します。
- Anacondaのインストール(Python3系が良いです)
- さっそくAnaconda Navigatorを起動
- EnvironmentsのCreateから環境構築
再生ボタンを押して、Open Terminalをクリック
作成した環境でコマンドプロンプトを起動することができます
Slack Botアカウントの作成
-
SlackでBot用のアカウントを作成します。
チームのSlack作成方法等はSlackのホームページを見てください。 -
権限のあるユーザーでログインしている状態でここをクリックします。
Botアカウントの作成画面が開きます。
-
好きなユーザー名を入力して、Add bot integrationをクリックします。
API Tokenという部分が必要になるので、ここをメモっておいてください。
-
適当にBotさんをカスタマイズ。
コードを作成してBotを動かす
-
Slackbotをインストール。Anacondaで作成した環境でコマンドプロンプトに以下のコードを入力するとできます。
pip install slackbot
-
run.py
に以下のコードを入力run.pyfrom slackbot.bot import Bot def main(): bot = Bot() bot.run() if __name__ == "__main__": print('start slackbot') main()
-
botアカウントのトークンを指定。
slackbot_settings.py
に以下のコードを入力slackbot_settings.pyAPI_TOKEN = "さっきメモしたAPIToken" # このbot宛のメッセージで、どの応答にも当てはまらない場合の応答文字列 DEFAULT_REPLY = "何言ってんだこいつ" PLUGINS = [ 'plugins', ]
-
コードを保存したら、再びコマンドプロンプトを表示。
run.pyの存在するディレクトリに移動して、以下のコマンドを実行します。
python run.py
-
作成したアカウントと会話しましょう。
すべての言葉に対して"何言ってんだこいつ"というbotの完成です。
もっと会話をしてみる
特定の言葉に反応させる
先ほど作成したディレクトリ内のmy_mention.py
を編集することで、機能を追加できます。
例として以下のコードを書いてみます。
from slackbot.bot import respond_to # @botname: で反応するデコーダ
from slackbot.bot import default_reply # 該当する応答がない場合に反応するデコーダ
@respond_to('うそまる') #反応してほしい言葉
def mention_func(message):
message.reply('うそまるは偽物です。') # メンション
特定の言葉に反応してくれました。
コードについて簡単に解説。
まず、pluginsディレクトリについて。
pluginsディレクトリに作った_init_.py
こちらは、Slackbotのプラグインとして読み込ませるディレクトリがPythonパッケージである必要があるために作ったものです。
パッケージとして認識させているだけなので、中身は空です。
続いて、my_mention.py
主にこちらに追加したい機能に必要なコードを書きます。
respond_to
デコレータの引数に反応してほしい言葉をかくことで、Botに対するメンションに反応するように登録されます。
mention_func
のmention
部分はファクション名なので、
他の言葉に対してもメンション機能を追加したい場合はここの名前を変えます。
最後にslackbot_settings.py
こちらに書いた下のコード部分
PLUGINS = [
'plugins',
]
こちらはプラグインロードが行われるようにするために記載します。
なので、plubins
部分には任意のディレクトリ名が入ります。
天気予報を取得する
天気情報APIを使って今日の天気情報を取得します。
このサイトではjson形式でデータを返してくれるので、
ここから必要な情報を取得します。
今回は本日の天気と天気に伴ったアイコンを表示させる方法を紹介します。
機能を追加するので、my_mention.py
に以下のコードを追加します。
@respond_to('今日の天気')
def weather(message):
import urllib
import json
url = 'http://weather.livedoor.com/forecast/webservice/json/v1?city='
# '130010'とすると東京の情報を取得してくれる
# ここを変えれば任意の地域の天気情報を取得できる
city_id = '130010'
html = urllib.request.urlopen(url + city_id)
jsonfile = json.loads(html.read().decode('utf-8'))
title = jsonfile['title']
telop = jsonfile['forecasts'][0]['telop']
#telopが晴れだったら晴れのスラックのアイコンとか場合分け
telop_icon = ''
if telop.find('雪') > -1:
telop_icon = ':showman:'
elif telop.find('雷') > -1:
telop_icon = ':thinder_cloud_and_rain:'
elif telop.find('晴') > -1:
if telop.find('曇') > -1:
telop_icon = ':partly_sunny:'
elif telop.find('雨') > -1:
telop_icon = ':partly_sunny_rain:'
else:
telop_icon = ':sunny:'
elif telop.find('雨') > -1:
telop_icon = ':umbrella:'
elif telop.find('曇') > -1:
telop_icon = ':cloud:'
else:
telop_icon = ':fire:'
text = title + '\n' + '今日の天気 ' + telop + telop_icon
message.send(text)
今日の天気を聞いてみましょう。
再びコードを軽く説明。
まずtitleとtelop部分。
こちらは上記にリンクを貼った天気予報APIのプロパティ名を参考にし、
自分が欲しいプロパティ名を[' ']の中に書くことで、プロパティ名に付随する情報を取得できます。
ただし、telopで取得しているforecastsプロパティに関しては、配列形式でデータが挿入されています。
配列の0番目が今日の天気、1番目が明日の天気、2番目が明後日の天気です。
今回は今日の天気を取得したいため、配列の0番目を指定しています。
続いてif文によって分岐している部分ですが、
こちらはtelopで取得した天気ワードを基に、表示させるスラックアイコンを分岐させています。
最後にtext部分でbotに表示させる言葉をつなぎ合わせています。
最高気温を取得したりもできるので、今後カスタマイズの価値があります。
遅延情報を取得する
最後に列車の遅延情報を取得します。
こちらの遅延情報JSONを使って、天気予報を取得した時と同様の方法を使います。
再び機能追加なので、my_mention.py
に以下のコードを追加します。
@respond_to('電車遅れてる?')
def train(message):
import urllib
import json
url = 'https://rti-giken.jp/fhc/api/train_tetsudo/delay.json'
html = urllib.request.urlopen(url)
jsonfile = json.loads(html.read().decode('utf-8'))
for json in jsonfile:
name = json['name']
company = json['company']
text = company + name + 'が遅延してるぴょん♪'
message.send(text)
表示させてみます。
まだ地域ごとの遅延情報を表示させるようにカスタマイズしていないため、
全国の遅延情報が出てしまいます。
今後は地域ごとの遅延情報カスタマイズやお勧めのレストランを紹介してくれるbotを作成予定。
参考ページ
- PythonのslackbotライブラリでSlackボットを作る
- PythonでSlackbotを作る(1)
- PythonでSlackbotを作る(2)
- 初心者に捧げる対話システムの作り方
- Pythonを使ってSlack Botを作成してみた
##つづき