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

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

新規登録して質問してみよう
ただいま回答率
85.35%
Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google カレンダー

Google カレンダーは、Google社が提供する無料のスケジュール管理ツールです。パソコンやスマートフォン、タブレットなどからアクセスし、スケジュールの追加・変更が可能。Googleアカウントがあれば誰でも使用できます。

Slack

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

Q&A

0回答

1609閲覧

複数のカレンダーの情報をスラックで通知したい

onmonm027

総合スコア2

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google カレンダー

Google カレンダーは、Google社が提供する無料のスケジュール管理ツールです。パソコンやスマートフォン、タブレットなどからアクセスし、スケジュールの追加・変更が可能。Googleアカウントがあれば誰でも使用できます。

Slack

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

0グッド

0クリップ

投稿2020/04/22 07:58

複数のメンバーのカレンダーの内容を。毎日Slackでまとめてみられるように通知したいです。
https://bzbot.work/2019/04/10/googlecalendar-slack/
こちらを参考にしたのですが、エラーは出ませんがSlackに通知が来ません…。
初心者なもので、どこがおかしいのか見当もつきません。
ご教示お願い致します!

var date = new Date(); //アクティブなシートを取得 var sheet = SpreadsheetApp.getActiveSpreadsheet(); //「calendar_ID」のシートをアクティブにして、シート情報をcalendarIdに取得 var calendarId = sheet.getSheetByName('Calendar_ID'); Logger.log(calendarId.getName()); //カレンダーにセットされているGoogleCalendarのIDを取得する function getId(){ //calendarIDが入っている最終行を取得(固定) var lastR1 = calendarId.getLastRow(); Logger.log("【lastR】:" + lastR1); //セットされているIDのリストを順番に取得してgetCalに引数として渡す for (var i = 1; i < lastR1 ; i++){ //カレンダーIDを指定して、カレンダーを取得 var calId = calendarId.getRange('A'+(i+1)).getValue(); Logger.log('【calId】' + calId); //IDを渡してカレンダーから情報を取得 var msg = getCal(calId); //取得したカレンダーの情報をSlackにPOSTする sendToSlack(msg); } } function getCal(id) { Logger.log('【id】' + id); var message = ''; var calendar = CalendarApp.getCalendarById(id); //getEventsForDayは引数の日付の予定を全て取得する var events = calendar.getEventsForDay(date); //eventsに入っている要素の数だけ実行 for (var i = 0; i < events.length; i++) { Logger.log('events要素' + i + '目'); var title = events[i].getTitle(); var startTime = events[i].getStartTime(); var endTime = events[i].getEndTime(); var duration = (endTime - startTime) /(1000*60)/(60); var start = Utilities.formatDate(startTime,"JST","MM/dd hh:mm"); //1回目はアドレスをTOPに表示したいため(Slackで表示を加工するため細々記載している) if (i === 0){ message += id + '```' + '\n' + (i + 1).toString() + '.' + '[' + start + ' (' + duration + ')' + ']--' + title + '\n'; }else{ message += (i + 1).toString() + '.' + '[' + start + ' (' + duration + ')' + ']--' + title + '\n'; } } Logger.log('message:' + message); //Slackで送る形式を指定したいため '```' を最後に追加 return message + '```'; } function sendToSlack(postMsg) { Logger.log('postMsg:' + postMsg); //Slackのチャンネル名を指定 var ch = "#test_slackmf"; //SlackのwebhookURLを指定 var url = "https://hooks.slack.com/services/●●●"; //渡すデータを指定する var data = { "channel" : ch, "username" : "Googlecalendar-Bot", "text" : postMsg, "icon_emoji" : ":spiral_calendar_pad: " }; var payload = JSON.stringify(data); var options = { "method" : "POST", "contentType" : "application/json", "payload" : payload }; var response = UrlFetchApp.fetch PropertiesService.getScriptProperties().getProperties().url,options} コード

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問