Pythonを使ってSlackの過去ログを保存したいと思っています。
以下のリンクに、Slackのbotと連携することでログを保存する方法があったので、そちらを参考にしています。
https://miyabikno-jobs.com/record-input-slackbot/
リンク先のコードを引用して一部を書き直したコードが以下になります。
Python
1from slackbot.bot import listen_to 2import datetime 3from filereadwrite import FileReadWrite 4 5 6@listen_to('^(.*)$') 7def comment_log(message, text): 8 target_channels = ['ログ保存テスト'] 9 target_users = ['hhh_ds'] 10 # チャンネル名を取得 11 channel = message.channel._body['name'] 12 13 # 対象チャンネルでなければ何もしない 14 if channel not in target_channels: 15 return 16 17 # 名前と表示名を取得する 18 real_name = message.user['real_name'] 19 display_name = message.user['profile']['display_name'] 20 21 # 対象ユーザーでなければ何もしない 22 if real_name not in target_users and display_name not in target_users: 23 return 24 25 # 書き込みクラスのインスタンスを生成 26 f = FileReadWrite() 27 28 # 現在時刻の取得 29 now = datetime.datetime.now() 30 # 時刻を文字列に変換する 31 str_now = now.strftime("%Y/%m/%d %H:%M:%S") 32 33 # 出力情報(時刻,名前/表示名,チャンネル名,入力した文字列) 34 output = "%s,%s/%s,%s,%sn" % (str_now, real_name, display_name, channel, text) 35 36 # ファイルにデータを書き込む 37 result = f.file_write("test.log", output) 38 # 書き込みに失敗した場合は応答する。それ以外は無応答 39 if result == 'ng': 40 message.reply("書き込みに失敗しました")
変更したのは8行目と9行目の=以降です。
botを起動させた上でコードを実行したのですが、test.logが生成されません。
エラーも発生せず、コード内で指定した「書き込みに失敗しました」の表示も出ません。
どこで問題が起きているのでしょうか。
お知恵を貸していただけると幸いです。
あなたの回答
tips
プレビュー