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

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

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

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

解決済

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

FHos
FHos

総合スコア0

Google Apps Script

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

1回答

0評価

1クリップ

1139閲覧

投稿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も参考にしました。

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

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

qnoir

2022/01/05 09:17 編集

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

2022/01/07 03:12

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

2022/01/07 06:13

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

2022/01/07 07:08

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

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Google Apps Script

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