Googleフォームからの回答を1問1行ずつに直したのち、別のスプレッドシートへコピーしたいです。
以下コードを実行すると、エラーはなく、フォームの回答を1問1行に直すのはできるのですが、別のスプレッドシートへのコピーができていません。
さらに、デバッグのためにLoger.log()による確認もしているのですが、ログが表示されません。
解決方法をお教え願います。
GAS
1function myFunction() { 2 3 //本シートの最終行を読み込み 4 var sheet = SpreadsheetApp.getActiveSheet(); 5 var lastRow_no = sheet.getLastRow(); 6 var RowValues = sheet.getRange(lastRow_no,1,1,sheet.getLastColumn()).getValues(); 7 RowValues = Array.prototype.concat.apply([], RowValues); 8 var lastRow_len = RowValues.filter(String).length; 9 10 //本シートを4列ずつに編集 11 var num_copy = Math.floor((lastRow_len/2)-2) 12 for(i=1; i <= num_copy; i++){ 13 //2投稿目以降を下の行へコピぺ 14 let copyRange = sheet.getRange(lastRow_no,3+(2*i),1,2) 15 let pasteRange = sheet.getRange(lastRow_no+i,3,1,2) 16 copyRange.copyTo(pasteRange); 17 //コピー元のセル内容を削除 18 copyRange.clear(); 19 //投稿者投稿日時を下の行へコピペ 20 let copyTytle = sheet.getRange(lastRow_no,1,1,2) 21 let pasteTytle = sheet.getRange(lastRow_no+i,1,1,2) 22 copyTytle.copyTo(pasteTytle); 23 } 24 25 //コピー先のシート最終行の1つ下の行数を読み込み 26 var sheet_merged = SpreadsheetApp.openById("XXXXXXXXXXX"); 27 var target_sheet = sheet_merged.getSheetByName('シート1'); 28 var pasteRow_merged = target_sheet.getLastRow()+1; 29 30 //コピー 31 let sourceRange = sheet.getRange(lastRow_no,1,num_copy+1,4) 32 let targetRange = target_sheet.getRange(pasteRow_merged,1,num_copy+1,4) 33 var values = sourceRange.getValues(); 34 targetRange.setValues(values); 35} 36
あなたの回答
tips
プレビュー