前提・実現したいこと
GASを使って複数人の1か月分のGoogleカレンダーの予定をスプレッドシートに移したい
発生している問題・エラーメッセージ
エラー
Exception: Invalid argument
(匿名) @ コード.gs:7
ーーーーーーーーーーーーーーーーーーーーーーーーーーー 初めて質問させていただきます。 複数人のGoogleカレンダーをまとめてスプレッドシートに記載したいと思っています。 以下の記事を参考にさせていただきましたがうまくいきません。 <参考URL> https://bzbot.work/2019/02/21/gas-calendar-2/ 以下に私がやった手順を記載いたします。 ①シートの添付の画像のように複数人のIDを記載する。 このシートの名前は「シート1」にしています。 ![![イメージ説明](27dd4b49d0f4289930546dc6462410f0.png)](5ead7d4685f01d989b5027d68fa123de.png) ②以下のコードをスクリプトエディタに記載 //対象の日付を範囲指定 var date = '2021/01/01'; //アクティブなシートを取得 var sheet = SpreadsheetApp.getActiveSpreadsheet(); //「Calendar_ID」のシートをアクティブにして、シート情報をcalendarIdに取得 var calendarId = sheet.setActiveSheet(sheet.getSheetByName("Calendar_ID")); //「Calendar_Item」のシートをアクティブにして、シート情報をcalendarItemに取得 var calendarItem = sheet.setActiveSheet(sheet.getSheetByName("Calendar_Item")); function getId(){ //現在の入力されてる値を初期化 calendarItem.clear(); //ヘッダ行に入る値を指定(誤って削除しても都度指定) calendarItem.getRange('A'+(1)).setValue('カレンダーID'); calendarItem.getRange('B'+(1)).setValue('タイトル'); calendarItem.getRange('C'+(1)).setValue('開始時刻'); calendarItem.getRange('D'+(1)).setValue('終了時刻'); calendarItem.getRange('E'+(1)).setValue('所要時間'); calendarItem.getRange('F'+(1)).setValue('詳細'); calendarItem.getRange('G'+(1)).setValue('住所'); //CalendarIDが入っている最終行を取得(固定) var lastR1 = calendarId.getLastRow(); Logger.log("【lastR】:" + lastR1); //セットされているIDのリストを順番に取得してgetCalに引数として渡す for (var i = 1; i < lastR1 ; i++){ //予定表が入っている最終行を取得(可変) var lastR2 = calendarItem.getLastRow(); Logger.log("【lastR】:" + lastR2); //カレンダーIDを指定して、カレンダーを取得 var calId = calendarId.getRange('A'+(i+1)).getValue(); Logger.log('【calId】' + calId); getCal(calId,lastR2); } } function getCal(id,lastR) { Logger.log('【id】' + id); Logger.log('【lastR】' + lastR); var calendar = CalendarApp.getCalendarById(id); //この時はまだfrom,end両方に変数dateで指定した日付が入っている var from= new Date(date); var end = new Date(date); //月を指定するときは必ず大文字のMMを指定します(半角mmだとminutesを指してしまう) //endのMonthm(月)に+1をして翌月を指定 end.setMonth(end.getMonth()+1); //getEventsで取得したいカレンダーの始まりと終わりを指定 var events = calendar.getEvents(from, end); //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(); //取得した値をスプレッドシートに反映 calendarItem.getRange('A'+(lastR+1)).setValue(id); calendarItem.getRange('B'+(lastR+1)).setValue(title); calendarItem.getRange('C'+(lastR+1)).setValue(startTime).setNumberFormat('yyyy/mm/dd hh:mm'); calendarItem.getRange('D'+(lastR+1)).setValue(endTime).setNumberFormat('yyyy/mm/dd hh:mm'); calendarItem.getRange('E'+(lastR+1)).setValue(duration); //calendarItem.getRange('E'+(lastR+1)).setValue(detail); calendarItem.getRange('G'+(lastR+1)).setValue(location); lastR = lastR + 1; } } ③実行を推すと上に記載のあるエラーコードが出ました。 お答えいただけますと幸いです。 よろしくお願いいたします。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/04/12 03:33
2021/04/12 03:55 編集
2021/04/13 08:41 編集
2021/04/13 13:45