以前、Tableau Serverのダッシュボードをサブスクライブ機能を使って、Outlook経由でもって、Slackに投稿する記事を公開しました。
今回も同様処理を試みようと思いましたが、画像をアップロードするのに苦戦しています。
完璧ではございませんが、
とりあえず、画像情報付きのメッセージをTeamsに上げる方法を紹介します。
チャネルを作成し、Webhookを追加する
チャネルの作成
Teamsの「・・・」ボタンを押下し、チャネルを追加します。
data:image/s3,"s3://crabby-images/72d71/72d71b0f8b46b885736e227687a1b6a625fda943" alt=""
チャネル名を設定し、追加。
data:image/s3,"s3://crabby-images/3af84/3af8483a16126eb5bcc9f240a6321b3820de6d98" alt=""
Incoming Webhook アプリの追加
次にAppsから「Incoming Webhook」を追加します。
左下部の「アプリ」押下し、「webhook」で検索
webhook関連のアプリが表示されるので
「Incoming Webhook」を選択します。
data:image/s3,"s3://crabby-images/1cd5b/1cd5bcc200d7db9043086091cc95b83e5170b421" alt=""
「チームに追加」を押下します。
data:image/s3,"s3://crabby-images/08e7c/08e7ca064890510576d59320f6d256ac01aa77f3" alt=""
中央部でチャネルを選択し、「コネクタを設定」をクリックします。
data:image/s3,"s3://crabby-images/f5194/f51948a2530e04b5583e2ecb6a320987d09a9924" alt=""
名前を入力し、「作成」をクリックします。
data:image/s3,"s3://crabby-images/ee035/ee03590bb1ab9d6ff5e68a63dd7757dc19e292d2" alt=""
すると以下の通り、URLボックスが表示されるのでコピーします。
data:image/s3,"s3://crabby-images/aca7c/aca7c04642696734ab3ccc4cac2d3ed2235a5222" alt=""
チャネルに戻ると以下の通り、作成したアプリが追加されたことを確認できます。
data:image/s3,"s3://crabby-images/6deca/6deca96c45b786c5b2b1701edfadef291893796f" alt=""
PythonからTeamsに投稿する
前回のTableau ServerからSlackに連携する方法と同じ処理をします。
細かな説明はこちらをご確認下さい。
Outlookへのログイン
Microsoft 365へのログインの場合
from exchangelib import Credentials, Account, FileAttachment
credentials = Credentials(username='<outlookのログインID>', password='<outlookのログインパスワード>')
account = Account('<outlookのメールアドレス>', credentials=credentials, autodiscover=True)
Exchange Serverの場合
from exchangelib import DELEGATE, Account, Credentials, Configuration, FileAttachment
credentials = Credentials(username = '<ユーザー>',password = '<パスワード>')
config = Configuration(server='<サーバー情報>', credentials=credentials)
account = Account(
primary_smtp_address = '<メールアドレス>',
config = config,
autodiscover = False,
access_type = DELEGATE
)
Outlookに送信されたTableau Serverのダッシュボード画像をローカルに保存
import os
path = '<画像ファイルを保存するローカルパス>'
for item in account.inbox.filter('subject:<Tableau配信メールの件名>').order_by('-datetime_received')[:1]:
for attachment in item.attachments:
if isinstance(attachment, FileAttachment):
filepath = os.path.join(path, attachment.name)
with open(filepath, 'wb') as file:
file.write(attachment.content)
保存した画像をメッセージと共にTeamsに連携
import requests
import json
import base64
webhook = '<Teamsで取得したWebhookのURL>'
with open(filepath, "rb") as file:
base64image = base64.b64encode(file.read()).decode("ascii")
image = "![]" + "(" + f"data:image/png;base64,{base64image}" + ")"
data = {
"title": "<タイトル>",
"text": image
}
headers = { "Content-type": "multipart/form-data" }
requests.post(webhook, json = data, headers = headers)
画像情報はエンコードしています。
実行してみました。
data:image/s3,"s3://crabby-images/39b64/39b641efd422e65190c26be9156adfbb56233425" alt=""
・・・結論申しますと、こちらrequests上は200で正常処理されますが、画像情報はTeamsに投稿されませんでした。
というのも「HTTP error 413」で落ちているっぽいです。
つまり、画像情報をエンコードした際の文字列が長すぎたようです。
以下の小さな画像を用意して、試しに上記を実行してみました。
用意した画像
data:image/s3,"s3://crabby-images/8969a/8969af3e3d5f67d8a4097cee9ce836c5e96bc214" alt=""
実行結果
data:image/s3,"s3://crabby-images/9970f/9970f6ccb76e97ac0a41f4fdf4e69e2a1a964511" alt=""
送れた!と思ったら、表示枠切れてます。
こちらの画像、ダウンロードしたところ、画像自体は切れていませんでした。表示の問題だけのようですが。。。
とはいえ、これではTableauのダッシュボードの画像をTeamsに送信できたとしても使い物になりません。
困りました。
とりあえず、Microsoft Teamsに投稿する場合は制限を気にする必要があることが分かりました。
本来はTeams内である程度議論を完結させたかったですが、
今時点ではTableau ServerのURLも含めて送る等、工夫が必要です。
もうしばらく色々と調べてみます。
参考になる記事でなく、恐縮です。
では。