2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Google Apps Script (GAS)でGoogleカレンダーにシフト登録する。

Last updated at Posted at 2024-03-31

概要

Googleカレンダーに自分のシフトを一括で登録するGASを実装した際のメモです。

スプレッドシートのコピー版を以下で公開中です。
シフト管理(公開用)

前提

今回はシフトの種類は2交代制(日勤、夜勤、夜勤明け、休日)を想定しています.(スプレッドシートとGASの修正すれば色々なパターンに対応できると思います。

使い方の流れ

  1. 「Googleカレンダー登録」ボタンを押すと、アプリの許可を求められるので注意事項を読んで許可して下さい。
    ※初回のみ
  2. スクリプトプロパティで登録先のGoogleカレンダーID(CALENDAR_ID)を設定
    ※初回のみ
  3. 「雛形」シートをコピーして、赤セルの年月を更新
  4. スプレッドシートで予定を記入
    シフト管理1.png
  5. 「Googleカレンダー登録」ボタンを押すと指定したカレンダーに反映される
    シフト管理2.png

Googleカレンダーへの登録スクリプト

function createScheduleOnGoogleCalendar() {
  var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
  
  // 対象となる範囲のセル座標を定義
  var ranges = ['B3:H3', 'B5:H5', 'B7:H7', 'B9:H9', 'B11:H11', 'B13:C13'];
  
  var calendarData = [];
  
  // 各範囲について日付とシフトを取得し、リストに追加
  ranges.forEach(function(rangeStr) {
    var range = sheet.getRange(rangeStr);
    var dates = range.getValues()[0];
    var shiftRow = range.offset(1, 0, 1, range.getNumColumns());
    var shifts = shiftRow.getValues()[0];
    
    for (var i = 0; i < dates.length; i++) {
      var date = dates[i];
      var shift = shifts[i];
      calendarData.push({ date: date, shift: shift });
    }
  });
  
  //スクリプトプロパティに格納したデータベースID、トークンを取得
  const props  = PropertiesService.getScriptProperties();
  const calendarId = props.getProperty('CALENDAR_ID');
  let myCalendar = CalendarApp.getCalendarById(calendarId);


  //シフトの種類、カレンダーで表示する色を設定。デフォルトは、終日での登録になるが、時間をいじることで変更可能
  const SHIFTS = {
    日勤: {
      color: CalendarApp.EventColor.YELLOW,
      startHour: 0,
      endHour: 24
    },
    休み: {
      color: CalendarApp.EventColor.PALE_RED,
      startHour: 0,
      endHour: 24
    },
    夜勤: {
      color: CalendarApp.EventColor.BLUE,
      startHour: 0,
      endHour: 24 // 翌日の朝9時まで
    },
    明け: {
      color: CalendarApp.EventColor.MAUVE,
      startHour: 0,
      endHour: 24
    }
  };

  for (var i = 0; i < calendarData.length; i++) {
    var event = calendarData[i];
    var shift = event.shift;
    var shiftInfo = SHIFTS[shift]; // シフトの種類に対応する情報を取得
    Logger.log(shiftInfo)
    // 開始日時と終了日時を設定
    if (shiftInfo) {
      var startDate = new Date(event.date.getFullYear(), event.date.getMonth(), event.date.getDate(), shiftInfo.startHour, 0, 0);
      var endDate = new Date(event.date.getFullYear(), event.date.getMonth(), event.date.getDate() + (shiftInfo.endHour < shiftInfo.startHour ? 1 : 0), shiftInfo.endHour, 0, 0);

      // イベントを作成
      var createdEvent = myCalendar.createEvent(shift, startDate, endDate);
      createdEvent.setColor(shiftInfo.color);
    }
  }

  var result = Browser.msgBox("完了", Browser.Buttons.OK);
}

スマホからスクリプトを実行したい

図形に割り当てたスクリプトはスマホから起動できないので以下の仕組みを作る。

以下のようなトリガーを作成し、スプレッドシートに変更があった時にinvokeを実行
シフト管理3.png

スプレッドシートのチェックボックスがTRUEになっているときだけ、createScheduleOnGoogleCalendar()を実行させる。

function invoke(){
  //スマホでカレンダー登録するための関数。TRUEになったらカレンダー登録する
  var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
  if (sheet.getRange('J10').getValue()){
    createScheduleOnGoogleCalendar();
    sheet.getRange('J10').setValue(false);
  }
}

まとめ

GASで、スプレッドシートの情報からGoogleカレンダーにシフトを一括登録する方法のご紹介でした。

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?