質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google フォーム

Google フォームは、 Google社が提供しているアンケートフォーム作成および集計ができる無料のツール。Googleアカウントがあれば利用が可能です。集計データは、スプレッドシートに収集され、データ分析もできます。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

0回答

490閲覧

GAS 作動しない部分がある

退会済みユーザー

退会済みユーザー

総合スコア0

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google フォーム

Google フォームは、 Google社が提供しているアンケートフォーム作成および集計ができる無料のツール。Googleアカウントがあれば利用が可能です。集計データは、スプレッドシートに収集され、データ分析もできます。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

1クリップ

投稿2021/11/18 05:04

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

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2021/11/18 13:14 編集

(自分の環境では、記載のコードは正しく動作しました) ①「デバッグのためにLoger.log()による確認もしているのですが、ログが表示されません。」とのことですが、コードのどの部分に、どのようなLogger.logを置いたときに、ログが表示されないのでしょうか? ②下記のスプレッドシートのID(XXXXXXXXXXX)は、想定するコピー先のIDになっていますか? たとえば var sheet_merged = SpreadsheetApp.openById("XXXXXXXXXXX"); var target_sheet = sheet_merged.getSheetByName('シート1'); の下に target_sheet.getRange("A1").setValue("test") を追加して実行した場合でも、想定するシートの「シート1」のA1セルは「test」という文字列に変化しないでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問