前提・実現したいこと
GASで、カレンダーからバイトの予定(仕事名・開始時間・終了時間・時給)を取得して、スプレッドシートに出力し、スプレッドシート側で時給や月の給料などの計算をしてくれるようにしたいと考えています。
2021年の1月から12月までのそれぞれの予定を12枚のシートに出力する機能を実装しようとしましたがうまくいきません。
発生している問題・エラーメッセージ
どうやら、カレンダーのデータを二次元配列として取得したものの要素の数を調べられないようです。
取得そのものがうまくいっていないのでしょうか。。?
TypeError: Cannot read property 'length' of undefined(行 36、ファイル「2021」)
該当のソースコード
GoogleAppsScript
1const CALENDAR_ID = '3b54dcmfvrn37jardohqfurmus@group.calendar.google.com'; //カレンダーID 2 3function getCalendarEvents() { 4 const calendar = CalendarApp.getCalendarById(CALENDAR_ID); 5 6 let y; 7 let result; 8 let i = result; if(y = 12){result = 1}else{result = y+1}; 9 10 for( 11 x = 0, 12 y = 1, 13 z = 2021, 14 sheet = SpreadsheetApp.getActiveSpreadsheet().getSheets()[x], 15 startTime = new Date('2021/y/01 00:00:00'), 16 endTime = new Date('z/i/01 00:00:00'); 17 y < 13; 18 x++,y++) 19 20 { 21 let events = calendar.getEvents(startTime, endTime); 22 let values=[]; 23 for(let event of events){ 24 let record = [ 25 event.getTitle(), 26 event.getStartTime(), 27 event.getEndTime(), 28 event.getDescription() 29 ]; 30 values.push(record); 31 if(y = 12){z++} else {}; 32 } 33 34 let resetRange = sheet.getRange("A11:D50"); 35 resetRange.clearContent(); 36 let writeRange = sheet.getRange(11,1, values.length, values[0].length); 37 writeRange.setValues(values); 38 } 39} 40 41
試したこと
getSheets()[0]のところをgetActiveSheet()に変更しても変わりません。
古い方のエディタでもだめです。
補足情報(FW/ツールのバージョンなど)
参考。。というか、元にしたサイトです。これの月ごとに振り分けてくれるバージョンを作りたいです。
https://tonari-it.com/gas-calendar-spreadsheet/
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/01/02 11:50