質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Raspbian

Raspbianは、DebianベースのRaspberry Pi用ディストリビューション。ハードウェア浮動小数点演算を有効にすることが可能で、Webブラウズなどの速度を向上できます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Raspberry Pi

Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。

Slack

Slackは、Tiny Speckという企業からリリースされたコミュニケーションツールです。GoogleDriveやGitHubなど、さまざまな外部サービスと連携することができます。

Q&A

解決済

1回答

3878閲覧

(Raspbianでプロキシ環境下)slackbotライブラリ使用時のエラー

matcha_33

総合スコア7

Raspbian

Raspbianは、DebianベースのRaspberry Pi用ディストリビューション。ハードウェア浮動小数点演算を有効にすることが可能で、Webブラウズなどの速度を向上できます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Raspberry Pi

Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。

Slack

Slackは、Tiny Speckという企業からリリースされたコミュニケーションツールです。GoogleDriveやGitHubなど、さまざまな外部サービスと連携することができます。

0グッド

0クリップ

投稿2018/03/05 05:22

編集2018/03/05 06:00

前提・実現したいこと

最終的に実現したいのは、こちらのように、Raspberry Piとセンサ、slackを使用して、部屋の空き状況を取得することなのですが、
この質問においては、pythonでslackのbotを作成したいです。

発生している問題・エラーメッセージ

上記の記事や、
PythonのslackbotライブラリでSlackボットを作る - Qiita
などを見ながら、初期設定をしていたのですが、run.pyを実行した時点でエラーが発生しました。

$python3 run.py start slackbot Traceback (most recent call last): File "run.py", line 11, in <module> main() File "run.py", line 6, in main bot = Bot() File "/home/pi/.local/lib/python3.5/site-packages/slackbot/bot.py", line 25, in __init__ 'BOT_EMOJI') else None File "/home/pi/.local/lib/python3.5/site-packages/slackbot/slackclient.py", line 37, in __init__ self.rtm_connect() File "/home/pi/.local/lib/python3.5/site-packages/slackbot/slackclient.py", line 42, in rtm_connect self.parse_slack_login_data(reply) File "/home/pi/.local/lib/python3.5/site-packages/slackbot/slackclient.py", line 65, in parse_slack_login_data proxy, proxy_port = os.environ['http_proxy'].split(':') ValueError: too many values to unpack (expected 2)

試したこと

①同じものを別のMacで実行したところ、上記の記事でも想定されている通りに動きました。
ラズパイは職場のプロキシ環境下にあるため、エラーメッセージからしてもプロキシの問題かと思うのですが、
初心者ゆえ、自分で作成したものではなくライブラリそのものを編集してしまっていいのか、
編集するとしたらどうしたらよいのか分からず、ご相談させていただきました。

②ラズパイ自体のプロキシ設定はしてあります。
apt.confと.bashrcにそれぞれ追加しました。


追加① dkato0077様からいただいた情報を試してみましたところ、
下記のエラーメッセージが表示されました。
※ ライブラリのslackcliant.pyの65行目、.split(':').rsplit(':', 1)に変更

$ python3 run.py start slackbot Traceback (most recent call last): File "/home/pi/.local/lib/python3.5/site-packages/websocket/_http.py", line 97, in _get_addrinfo_list addrinfo_list = socket.getaddrinfo(phost, pport, 0, 0, socket.SOL_TCP) File "/usr/lib/python3.5/socket.py", line 733, in getaddrinfo for res in _socket.getaddrinfo(host, port, family, type, proto, flags): socket.gaierror: [Errno -2] Name or service not known During handling of the above exception, another exception occurred: Traceback (most recent call last): File "run.py", line 11, in <module> main() File "run.py", line 6, in main bot = Bot() File "/home/pi/.local/lib/python3.5/site-packages/slackbot/bot.py", line 25, in __init__ 'BOT_EMOJI') else None File "/home/pi/.local/lib/python3.5/site-packages/slackbot/slackclient.py", line 37, in __init__ self.rtm_connect() File "/home/pi/.local/lib/python3.5/site-packages/slackbot/slackclient.py", line 42, in rtm_connect self.parse_slack_login_data(reply) File "/home/pi/.local/lib/python3.5/site-packages/slackbot/slackclient.py", line 70, in parse_slack_login_data http_proxy_port=proxy_port, http_no_proxy=no_proxy) File "/home/pi/.local/lib/python3.5/site-packages/websocket/_core.py", line 494, in create_connection websock.connect(url, **options) File "/home/pi/.local/lib/python3.5/site-packages/websocket/_core.py", line 217, in connect options.pop('socket', None)) File "/home/pi/.local/lib/python3.5/site-packages/websocket/_http.py", line 63, in connect hostname, port, is_secure, proxy) File "/home/pi/.local/lib/python3.5/site-packages/websocket/_http.py", line 100, in _get_addrinfo_list raise WebSocketAddressException(e) websocket._exceptions.WebSocketAddressException: [Errno -2] Name or service not known

どうぞよろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/03/05 05:51 編集

.split(':')の部分を.rsplit(':', 1)にしないとまずい気がしますね・・・試せていないので確証はないですが、
退会済みユーザー

退会済みユーザー

2018/03/05 06:12

ダメだったようですので、たぶん方針が間違っているんだと思います。環境変数をcan110さんの回答のようにいじってみるか、ですかね。
guest

回答1

0

ベストアンサー

slackは触ったことなく動作も未検証ですがソースコードを確認してみると
環境変数http_proxyhostname:8080のように設定されていることが前提の処理となっています。
すなわちhttp_proxyにはhttp://を含めてはいけないようです。

投稿2018/03/05 06:00

can110

総合スコア38233

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

matcha_33

2018/03/05 06:32

解決しました!ありがとうございます。 --- 自分のような初心者のため、少し追記です。 環境変数を上書きするのにもっといい方法もあるのだと思うのですが、 解決したときは、ライブラリのslackclient.pyの上のほうに `os.environ['http_proxy'] = hostname:8080`と追加しました。
can110

2018/03/05 06:38

ライブラリ側を修正してよければ「slackbot_http_proxy」という別環境変数を参照するように修正するのも手かと。 あるいはユーザーコード側で bak = os.environ['http_proxy'] # 一時退避 os.environ['http_proxy'] = 'hostname:8080' bot = Bot() os.environ['http_proxy'] = bak # 復帰 でもいけるかもしれません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問