GAS로 오늘 Google 캘린더를 Slack에 알립니다! – 2019년 버전

전회도 GAS를 Slack에 통지 시리즈였습니다만, 이번도 통지 시리즈입니다.
어느 쪽인가하면, 영업이나 현장 측의 관리 감독자가 정보를 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);
}

좋은 웹페이지 즐겨찾기