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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Google Apps Script

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

Q&A

解決済

1回答

4818閲覧

Googleフォームのプルダウンリストをスプレッドシートの内容で更新

FHos

総合スコア0

Google Apps Script

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

0グッド

1クリップ

投稿2022/01/05 03:00

編集2022/01/05 04:09

前提・実現したいこと

スプレッドシートのリストを、Googleフォームのプルダウンリストと連動
フォームの回答時にスプレッドシートの内容から、プルダウンリストも更新される

発生している問題・エラーメッセージ

エラーメッセージ Exception: 質問に重複した選択肢の値を追加することはできません。

該当のソースコード

function overwriteCastList() { /** // スプレッドシートの情報を取得する // **/  var SS = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('◯◯◯'); // スプレッドシートのH2のセルを指定 if("△△△" == SS.getRange("H2").getValue()){ // H行の3行目からコンテンツをもつ最後の行までの値を配列で取得する var colA = SS.getRange(3, 8, SS.getLastRow() - 1).getValues(); } /** // Googleフォームのプルダウン内の値を上書きする // **/ // GoogleフォームのIDを設定 →「https://docs.google.com/forms/d/〇〇〇/edit」の〇〇〇を↓に記述 var form = FormApp.openById('□□□□□□□□□□□□□□□□□□□'); // 質問項目がプルダウンのもののみ取得 var items = form.getItems(FormApp.ItemType.LIST); items.forEach(function(item){ // 質問項目が「△△△」を含むものに対して、スプレッドシートの内容を反映する if(item.getTitle().match(/△△△*$/)){ var listItemQuestion = item.asListItem(); var choices = []; colA.forEach(function(name){ if(name != ""){ choices.push(listItemQuestion.createChoice(name)); } }); // プルダウンの選択肢を上書きする listItemQuestion.setChoices(choices); } }); }

試したこと

https://qiita.com/kobaboy/items/610263087d9c85d8458e
以前こちらのサイトを参考に作成して、成功しています。

https://teratail.com/questions/290657
こちらのQ&Aも参考にしました。

スプレッドキー、フォームキーなど確認しましたが、解決できませんでした。
解決にご協力いただきたいです。

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2022/01/05 09:17 編集

エラーの通り、一つのリストボックスに、重複した値(=同じ値)を設定しようとしている可能性があります。 colA.forEach(function(name) の直後に console.log(name) を入れて実行したときのログ出力を確認してみてはいかがでしょうか。
FHos

2022/01/07 03:12

ご回答頂き有難うございます。 確認したところ、空白部分が抽出されており、Latrowの調整で、重複はなくしたのですが、それでもなお同じエラーが続いている状態です。 フォームの質問内容をまるごと上書きするような形式にしたいのですが、関数として不備などがあるのでしょうか? 何かご存知でしたらご教授いただけると幸いです。
退会済みユーザー

退会済みユーザー

2022/01/07 06:13

同じコードで手元でフォームとシートを作って実行してみたところ 特にエラーなく正常に質問内容が更新されています。 そちらのデータ固有の問題の可能性があるのですが、フォームとスプレッドシートのリンクを共有していただくことは可能でしょうか?
FHos

2022/01/07 07:08

ご検証いただきありがとうございます。 シートの公開をすることはできず、シートの中身を検証したところ重複部分を見つけました。 無事解決することが出来ました。有難うございました。
guest

回答1

0

自己解決

スプレッドシートの中身を修正することで解決できました。

投稿2022/01/07 07:09

FHos

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問