GAS로 오늘 Google 캘린더를 Slack에 알립니다! – 2019년 버전
어느 쪽인가하면, 영업이나 현장 측의 관리 감독자가 정보를 Google 캘린더나, 전회로 말하면 Google 폼에 갈 시간을 없애고, Slack에 통지를 하는 것으로 정보의 일원 관리를 실시할 수 있을 것 ! 라고 하는 일로 Slack를 잘 활용한 사례를 여러가지 만들어 갑니다.
단지 친숙하지만, 4류 이하의 스킬이기 때문에 큰 코드를 걸지 않는 것이 솔직한 곳입니다. 웃음
그래서 소개하고 있는 것은 앞으로 GAS를 기억하든지, 기억한 지 얼마 안된 것입니다! 라든지, GAS란 무엇인가? 라는 사람을 위한 기사뿐입니다!
사이트 소개
아래 다양한 GAS 및 기타 기사를 소개합니다!
htps : // bz 보트 t. rk /
소개 기사
이번 소개하고 있는 기사는 이하입니다!
htps : // bz 보트 t. rk/2019/04/10
송신 결과
캘린더 정보
이번 GAS 코드는 크게 3개의 기능으로 나누어 기술하고 있습니다.
첫 번째: GAS에서 스프레드시트에 등록된 ID 획득
두 번째: GAS에서 ID의 Google 캘린더 정보 얻기
세 번째: GAS로 Slack으로 보내기
구현
세세한 구현의 방법이거나 준비이거나는 기사쪽에 세세하게 써 있습니다.
GAS
//対象の日付を範囲指定
var date = new Date();
//アクティブなシートを取得
var sheet = SpreadsheetApp.getActiveSpreadsheet();
//「calendar_ID」のシートをアクティブにして、シート情報をcalendarIdに取得
var calendarId = sheet.setActiveSheet(sheet.getSheetByName('Calender_ID'));
//カレンダーにセットされている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 detail = events[i].getDescription(); //使ってない
//var location = events[i].getLocation(); //使ってない
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 = "#bzbot";
//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(url, options);
}
Reference
이 문제에 관하여(GAS로 오늘 Google 캘린더를 Slack에 알립니다! – 2019년 버전), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/Bzbot/items/285e0bf775324d8be4c2텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)