Twitter-LINE連携によるビジネス活用
2020.04.24
YouTubeでポイントを説明しています。画像をクリックすると再生できます。
今回は、Twitter に届いたツイートを、LINE に流し込む仕組みを構築します。
具体的には、あるプロジェクトで、その代表アカウントにツイートしたとします。
ラズパイ上のプログラムはツイートへの返信を監視して、返信があったときに、そのプロジェクトメンバーで構成されているライン・グループに自動的に投稿します。
プロジェクトのメンバーが、ライン上で返信に関して検討・意見交換をできるようにします。まあ、テレワーク的に仕事ができちゃうってところでしょうか。
■Twitterアプリ登録
Twitterが提供するAPIを使って、アプリケーションを作成するためには、Twitterへのアプリ登録が必要になります。
登録に関しては、【参考文献】のURLを参考にしてください。
アプリを登録して、各種Keyを発行します。
・Consumer Key(API Key)
・Consumer Secret(API Secret)
・Access Token
・Access Token Secret
Python用の設定ファイルを作成します
$ vi config.py
CONSUMER_KEY = "**********************"
CONSUMER_SECRET = "**********************"
ACCESS_TOKEN = "**********************"
ACCESS_TOKEN_SECRET = "**********************"
SCREEN_NAME = "project_pi"
ここでは、Twitter ユーザ名(スクリーンネーム)を "@project_pi" としています。
■python リクエスト・認証用ライブラリのインストール
pip3 をインストールしていない場合
$ sudo apt install python3-pip
$ sudo pip3 install requests requests-oauthlib
$ vi search.py
import json, config
from requests_oauthlib import OAuth1Session
CK = config.CONSUMER_KEY
CS = config.CONSUMER_SECRET
AT = config.ACCESS_TOKEN
ATS = config.ACCESS_TOKEN_SECRET
SN = '@'+config.SCREEN_NAME
twitter = OAuth1Session(CK,CS,AT,ATS)
url = "https://api.twitter.com/1.1/search/tweets.json"
params ={'q':SN,'count':10}
res = twitter.get(url, params = params)
since_id = ""
if res.status_code == 200:
timelines = json.loads(res.text)
for line in timelines['statuses']:
print(line['user']['name'])
print(line['user']['screen_name'])
print(line['created_at'])
print(line['id_str'])
print(line['text'])
print(line['in_reply_to_status_id_str'])
print('-------------------------------------------')
if since_id == "":
since_id = line['id_str']
else:
print("Failed: %d" % res.status_code)
print("since_id: %s" % (since_id))
$ python3 search.py
検索結果
-------------------------------------------
とある技術者1
engineer_1
Wed Apr 22 03:32:07 +0000 2020
1252802335086006272
@project_pi こんにちは、便利そうですね
1243502763658473472
-------------------------------------------
とある技術者2
engineer_2
Thu Apr 16 09:28:42 +0000 2020
1250738477866042369
RT @project_pi: ラズパイ活用講座 M5Stackキーボードを利用する
None
-------------------------------------------
since_id: 1252802335086006272
返信ツイートの場合、in_reply_to_status_id_str に返信元ツイート番号がはいります。
リツイートの場合は、None なので、この項目をみることでツイートの種類がわかります。
検索結果には、新しいものから古いものの順に格納されています。
ここでのポイントは、検索結果の一番最初のツイート番号を保存(since_id)して、
次回検索時の開始点として利用します。
params ={'q':SN,'since_id':'1252802335086006272','count':10}
1回の検索で取得できる最大ツイート数は200件ですが、
Twitter炎上にも備えて、取得するツイート数指定の count パラメターは、10程度に抑えておきましょう。
Twitter API では過去1週間以内のものが取得できます。
■Python3 で MySQL を使うための準備
ここでは、MySQLデータベース管理システムはすでにインストール済みとしています。
インストールの詳細は Raspberry Pi 3B+ 自宅WEBサーバ構築 第6回MySQL設定をご覧ください。
MySQLのデータベースに下記のようなテーブルを追加します。
create table sample_tbl(
screen_name varchar(32) default null,
since_id varchar(32) default null
) ENGINE=MyISAM default charset=utf8 auto_increment=1;
Twitter代表アカウントのレコードを1件追加します。
$ sudo mysql --user=root -p mysql
mysql> use sample_db;
mysql> insert into sample_tbl(screen_name) values('project_pi');
$ vi config.py
....
MYSQL_USER = "**********"
MYSQL_PASSWORD = "**********"
MYSQL_DBNAME = "sample_db"
MYSQL_TBLNAME = "sample_tbl"
Python用の MySQLクライアントをインストールします。
$ sudo apt-get install libmysqlclient-dev
$ sudo pip3 install mysqlclient
$ vi update.py
import MySQLdb, config
UR = config.MYSQL_USER
PW = config.MYSQL_PASSWORD
DB = config.MYSQL_DBNAME
TB = config.MYSQL_TBLNAME
SN = config.SCREEN_NAME
since_id = "1252802335086006272"
connection = MySQLdb.connect(
host='localhost', user=UR, passwd=PW, db=DB, charset='utf8')
cursor = connection.cursor()
cursor.execute("update %s set since_id=%s where screen_name='%s'" % (TB, since_id, SN))
connection.commit()
connection.close()
■LINENotifyの利用
通知の際に表示されるトークン名と、通知を送信するトークルームを選択して、トークンを発行します。
LINE Notify への登録方法は文末の【参考文献】を参照してください。
$ vi config.py
....
LINE_TOKEN = "********************"
$ vi lineNotify.py
#coding:UTF-8
import requests, config
LT = config.LINE_TOKEN
def main():
url = "https://notify-api.line.me/api/notify"
headers = {"Authorization" : "Bearer "+ LT}
message = 'これは、project_pi botから送信しています'
payload = {"message" : message}
r = requests.post(url ,headers = headers ,params=payload)
if __name__ == '__main__':
main()
■プログラムの統合
単体テストを行ってきたプログラムを1つに纏めます。
import MySQLdb, json, requests, config
from requests_oauthlib import OAuth1Session
SN = config.SCREEN_NAME
UR = config.MYSQL_USER
PW = config.MYSQL_PASSWORD
DB = config.MYSQL_DBNAME
TB = config.MYSQL_TBLNAME
CK = config.CONSUMER_KEY
CS = config.CONSUMER_SECRET
AT = config.ACCESS_TOKEN
ATS = config.ACCESS_TOKEN_SECRET
LT = config.LINE_TOKEN
connection = MySQLdb.connect(
host='localhost', user=UR, passwd=PW, db=DB, charset='utf8')
cursor = connection.cursor(MySQLdb.cursors.DictCursor)
query = 'select since_id from '+TB+' where screen_name=\''+SN+'\''
since_id = ""
cursor.execute(query)
for row in cursor:
since_id = row['since_id']
twitter = OAuth1Session(CK,CS,AT,ATS)
url = "https://api.twitter.com/1.1/search/tweets.json"
params ={'q':'@'+SN+' ','since_id':since_id,'count':10}
res = twitter.get(url, params = params)
since_id = ""
if res.status_code == 200:
timelines = json.loads(res.text)
url = "https://notify-api.line.me/api/notify"
headers = {"Authorization" : "Bearer "+ LT}
for line in timelines['statuses']:
name = line['user']['name']
screen_name = line['user']['screen_name']
created_at = line['created_at']
id = line['id_str']
text = line['text']
reply_id = line['in_reply_to_status_id_str']
if since_id == "":
since_id = line['id_str']
tweet = created_at[4:19]+' '+name+'@'+screen_name+' > '+text
payload = {"message" : tweet}
r = requests.post(url ,headers = headers ,params=payload)
else:
print("Failed: %d" % res.status_code)
if since_id != "":
cursor.execute("update %s set since_id=%s where screen_name='%s'" % (TB, since_id, SN))
connection.commit()
connection.close()
■crontab設定
$ vi project_pi.sh
#!/bin/bash
#
/usr/bin/python3 /home/ubuntu/scripts/project_pi.py > bot.log 2>&1
$ chmod u+x project_pi.sh
朝9時から午後5時まで15分間隔で処理を実行する。
$ sudo vi /etc/crontab
*/15 9-17 * * * root /home/ubuntu/scripts/project_pi.sh
$ sudo service cron restart
■補足
実際には、代表アカウントからの発信ツイートもプログラムから行います。
発信・返信ツイートすべてをデータベースに格納して、返信ツイート中の返信元ツイート番号から、該当する発信ツイートを検索・表示できるようにします。
■参考文献
・第23回「Raspberry PiからTwitterへ情報発信!(1) Twitter API編」
・PythonでTwitter API を利用していろいろ遊んでみる
・Standard search API
・Python3でMySQLを使う
・pythonでLINENotify使ってみる
|
Raspberry Pi(ラズベリー パイ)は、ARMプロセッサを搭載したシングルボードコンピュータ。イギリスのラズベリーパイ財団によって開発されている。
Arduinoで学ぶ組込みシステム入門(第2版)
●Arduinoを使って組込みシステム開発を理解する
・ハードウェアやソフトウェアなどの基礎知識/
・設計から実装までを系統的に説明するモデルベース開発/
・Arduinoを用いた実際の開発例
最新 使える! MATLAB 第3版
◆◆すぐに「使える!」 全ページフルカラー!◆◆
・MATLAB R2022bに対応し、解説もより詳しく!/
・コマンド・スクリプトの例が豊富で、動かして学べる!/
・超基本から解説。これから使いはじめる人にぴったり!/
・全編フルカラー、スクリーンショットも豊富!
Amazon Web Services基礎からのネットワーク&サーバー構築改訂4版
1.システム構築をインフラから始めるには/
2.ネットワークを構築する/
3.サーバーを構築する/
4.Webサーバーソフトをインストールする/
5.HTTPの動きを確認する/
6.プライベートサブネットを構築する/
7.NATを構築する/
8.DBを用いたブログシステムの構築/
9.TCP/IPによる通信の仕組みを理解する
C言語は第二の母国語: 独学学生時代から企業内IT職人時代に培った、独立のための技術とノウハウ 平田豊著
学生時代から独学でプログラミングをはじめ、企業内でデバイスドライバを開発し、そして独立後もたくさんのアプリケーション開発や技術書制作に携わってきた著者。その筆者が大事に使い続ける「C言語」の“昔と今”について、気づいたことや役立つ知識、使ってきたツールなどについて、これまで記してきたことを整理してまとめました。
本書では、現役プログラマーだけでなく、これからプログラミングを学ぶ学生などにも有益な情報やノウハウを、筆者の経験を元に紹介しています。
1冊ですべて身につくJavaScript入門講座
・最初の一歩が踏み出せる! 初心者に寄り添うやさしい解説
・最新の技術が身につく! 今のJavaScriptの書き方・使い方
・絶対に知っておきたい! アニメーションとイベントの知識
・プログラミングの基本から実装方法まですべて学べる
図解! Git & GitHubのツボとコツがゼッタイにわかる本
ソフトウェア開発では欠かすことのできないGit、GitHub。
これからGit、GitHubを使いたいという入門者の方でも、実際に手を動かしながら使い方を学べます。
C自作の鉄則!2023 (日経BPパソコンベストムック)
メーカー製のパソコンはスペックが中途半端で、自分が本当に欲しい機種がない――。そう思っている人には、ぜひ自作パソコンをお薦めします。自作パソコンのパーツは進化が速く、しかも驚くほど種類が豊富。価格も性能も、幅広く用意されているため、満足度100%の“自分だけの1台”を手に入れることができます。
Interface 2023年6月号
特集:第1部 フィルタ設計 基礎の基礎/
第2部 係数アプリや波形観測アプリで合点!FIR&IIRフィルタ作り/
第3部 配布プリント基板で体験!マイコンで動くフィルタ作り
日経Linux 2023年5月号
【特集 1】 AI時代の最強フリーソフト ~ 25のやりたいを実現!
【特集 2】 AWS、Azureのうまみを無料で体感!面倒なことはクラウドに任せよう
【特集 3】 新しいRaspberry Pi Cameraで遊んでみよう
【特集 4】 Linuxで旧型PCを復活! 1kg切るモバイルPCを「ChromeOS Flex」でChromebook化
ラズパイマガジン2022年秋号
特集:5大人気ボード 電子工作超入門
「半導体不足で在庫が不足し、電子工作のボードがなかなか買えない…」。そんな今にふさわしい特集を企画しました。5種の人気ボードにすべて対応した電子工作の入門特集です。「GPIO」や「I2C」を使った電子パーツの制御方法は、どのボードでも同じです。手に入れられたボードを使って、今こそ電子工作を始めましょう。
地方で稼ぐ! ITエンジニアのすすめ
学歴、理系の知識、専門スキル……全部なくてもITエンジニアになれる!
地方でも高収入でやりがいをもって働ける!ITエンジニアの魅力を一挙大公開
Raspberry Piのはじめ方2022
本書は、ラズパイやPicoの買い方やインストール、初期設定といった基本から、サーバー、電子工作、IoT、AIといったラズパイならではの活用方法まで、1冊でお届けします。
ラズパイをこれから始める方向けに、全36ページの入門マンガ「女子高生とラズベリーパイ」も巻末に掲載。これを読むだけでラズパイがどんなものなのか、すぐに分かって触れるようになります。
ハッカーの学校 IoTハッキングの教科書
生活にとけこみ、家電機器を便利にするIoT技術。
Webカメラなど、便利の裏側に潜むセキュリティの危険性をハッキングで検証。
専門家がパケットキャプチャからハードウェアハッキングまで、その攻撃と防御を徹底解説。
本書は2018年7月に刊行された「ハッカーの学校IoTハッキングの教科書」に一部修正を加えた第2版です。
攻撃手法を学んで防御せよ! 押さえておくべきIoTハッキング
本書は、経済産業省から2021年4月にリリースされた、IoTセキュリティを対象とした『機器のサイバーセキュリティ確保のためのセキュリティ検証の手引き』の『別冊2 機器メーカに向けた脅威分析及びセキュリティ検証の解説書』をもとに、IoT機器の開発者や品質保証の担当者が、攻撃者の視点に立ってセキュリティ検証を実践するための手法を、事例とともに詳細に解説しました。
ポチらせる文章術
販売サイト・ネット広告・メルマガ・ブログ・ホームページ・SNS…
全WEB媒体で効果バツグン!
カリスマコピーライターが教える「見てもらう」「買ってもらう」「共感してもらう」すべてに効くネット文章術
プログラマーは世界をどう見ているのか 西村博之著
イーロン・マスク(テスラ)、ジェフ・べゾス(Amazon)、ラリー・ペイジ(Google)…etc.
世界のトップはなぜプログラマーなのか?
ニーア オートマタ PLAY ARTS改 <ヨルハ 二号 B型 DX版> PVC製 塗装済み可動フィギュア
「NieR:Automata」より、ヨルハ二号B型こと2BがPLAY ARTS改に新たに登場!
高級感の感じられるコスチュームや髪の質感、洗練されたボディバランス、細かなデティールに至るまでこだわり抜かれた逸品。
DX版には通常版のラインナップに加え2Bの随行支援ユニット ポッド042などをはじめ“純白の美しい太刀"白の約定やエフェクトパーツ、自爆モードを再現できる換装用ボディパーツ、シーンに合わせて変えられる顔パーツ2種も付属する豪華な仕様に。
作中のあらゆるシーンを再現することが可能なファン必見の一品となっている。
Newtonライト2.0 ベイズ統計
ベイズ統計は,結果から原因を推定する統計学です。AIや医療などの幅広い分野で応用されています。その基礎となるのは18世紀に考えだされた「ベイズの定理」です。
この本では,ベイズ統計学のきほんをやさしく紹介していきます。
白光(HAKKO) ダイヤル式温度制御はんだ吸取器 ハンディタイプ FR301-81
無水エタノールP 500mlx2個パック(掃除)
ケイバ(KEIBA) マイクロニッパー MN-A04
サンハヤト SAD-101 ニューブレッドボード
白光(HAKKO) HEXSOL 巻はんだ 精密プリント基板用 150g FS402-02
[Amazon限定ブランド]【指定第2類医薬品】PHARMA CHOICE 解熱鎮痛薬 解熱鎮痛錠IP 100錠
|