入門GoogleAppsScript 就活のスケジュールを漏れなくカレンダーに反映させたい(後半)


⚠この記事には前半があります

前半をまだ読んでない方からすると、目標成果物も見えずナンノコッチャだと思いますので、そんな方はこちらから前回の記事をご覧ください

GoogleAppsScriptの始め方

前提条件:Googleアカウントを持っている

Googleアカウントを持っていないとGASは使えません!Googleのサービスですからね。
まだアカウントを持っていないという方はこちらから。

GASにアクセスする

https://script.google.com/home にアクセスするだけで◎

この画面がでれば大丈夫です。

プログラム組む

GASにアクセスできても実行する中身が無いのでは意味がないので、まずは試しに簡単なコードを組んでみましょう

日付を表示するプログラムを組む

コード.gsの中身に以下をコピペ

date.js
function date() {
  const today = new Date();
  // Date()の()の中身を変えることで日付は変更可能。デフォルトで今日の日付です
  console.log(today);
  // console.log()でカッコ内がどう表示されているのかをテストすることができます
};

GASを使ってカレンダーを操作する

覚えるべき項目

CalendarApp:クラス

Googleカレンダーを操作する上で絶対に必要。

getDefaultCalendar():メソッド

自分が使っているカレンダーを定義するときに使う。
自分で使うのならばだいたい最初に使う。

createEvent(title,startTime,endTime):メソッド

カレンダーに予定を立てるときに使う。
()の中身の項目を直接カレンダーに反映させることができる。

実際に使ってみる

useCalendar.js
function useCalendar(){

  const calendar = CalendarApp.getDefaultCalendar()
  calendar.createEvent("テストだよ", new Date("2021/10/01 10:00:00"), new Date("2021/10/01 12:00:00"));

};

これでGASを用いてカレンダーに入力することはできるが、ぶっちゃけめんどくさいですよね。
実はcreateEvent(title,startTime,endTime)は数学の代入のようなことができるんです。

入れ子を使ってみる

イメージは数学の代入と全く一緒!X+Yという式があって、Xに2、Yに3入れてみましょう。みたいな使い方ができます。便利ですね!

useCalendar.js
function useCal2(){
  //書き出しは同じ
  const calendar = CalendarApp.getDefaultCalendar();
  //最初に数学の方程式で言うX,Yを定義する
  const title = "テストだよ";
  const startTime = new Date("2021/10/01");
  const endTime = new Date("2021/10/01");

  calendar.createEvent(title,startTime,endTime);
  // こっちのほうがスマートで見やすいですよね!
};

SpreadSheetとの連携

スプレッドシートと連携するためには、先程学んだcalendarAppクラスではなく、SpreadsheetAppクラスを使う。習うより慣れろでコードを見てみましょう。

sheetToCal.js
function sheetToCal(){
  const calendar = CalendarApp.getDefaultCalendar();
  //---カレンダーはいつもどおりだが
  //---スプレッドシートはアプリが違うので…
  const spreadsheetId = ``;
  const spreadsheet = SpreadsheetApp.openById(spreadsheetId);
  //---SpreadSheetAppというクラスを用いる
  //---<キー>の部分はスプレッドシートのURLの/d/xxxxxxxxxxx/editのxxxxxxxxxxの部分が当てはまる
  const sheetName = ``;
  const sheet = spreadsheet.getSheetByName(sheetName);
  const range = sheet.getDataRange();
  const values = range.getValues();
  //---スプレッドシートはどれか、つかうシートはどれか、見る範囲はどれかを選択

  //---試しにvaluesが同表示されるのか見てみよう
  console.log(values);
  //---これでスプレッドシートが連携できたのがわかる
}

スプレッドシートとの連携は以上。
SpreadsheetAppクラスを用い、スプレッドシートとその中のシート、そして使うデータの範囲を定義する必要があります。

スプレッドシートのデータを入れ子にする

先程のコードでは、結果下記のようなものが見えたと思います。

黄色の枠で囲まれているのが一つのデータセットです。
このデータセットをそれぞれ定義するためにはfor(const...of...){}という式を使います。

sheetToCal.js
 for(const record of values){
  //---forはその中身を繰り返す指示をする
  //---const A of 配列 で A に対応する 配列の中身 を繋げることができる

    const status = record[0]
      //status = record[0](スプレッドシートのA列)
    const title = ("【就活】"+record[1]+record[2]);
      //status = record[0](スプレッドシートのB列+C列)
    const time = new Date(record[4]);
    const delta = new Date(record[5]);
    const startTime = new Date(record[3]);
      startTime.setHours(time.getHours());
      startTime.setMinutes(time.getMinutes());
    const endTime = new Date(startTime);
      endTime.setHours(endTime.getHours() + delta.getHours());
      endTime.setMinutes(endTime.getMinutes() + delta.getMinutes());
    const option = {
      location: record[6]
    };
  }
  calendar.createEvent(title,startTime,endTime,option)

こうすることによって、手で毎回イチから記載する以上に簡単にカレンダーを記載できる仕組みができましたね。

トリガーの設定

トリガーとは、「いつプログラムを実行するか」というきっかけを指します。
これがないといくら良いコード書いても使えませんからね!
まずは画像の通り、編集を押して現在のプロジェクトのトリガーを選択します。

そうすると以下のような画面に遷移します。

そしたら右下のトリガーを追加をクリック
以下の画像を参考に保存。

これでトリガーの設定は完了です!

終わりに

いかがでしたか?プログラミングって実はそんなに難しいものじゃなく、日々の暮らしを豊かに、簡単にしてくれるものなんです。

エンジニアにとって一番の仕事は調べることです。わからないことを調べることは「誰にでもできる」けれどほとんどの人がやっていないこと。だからそこに価値が出てきます。

そこから少しずつステップアップすることで分からないことが減り、自分のスキルというのを磨けるようになるんです。
ちょっとでもエンジニア職やITに興味を持っていただければ幸いです。
以下