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

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

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

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

Google フォーム

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

Google Apps Script

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

Q&A

解決済

2回答

570閲覧

重複しないデータをグループ分けしたい

sloth824

総合スコア3

Google スプレッドシート

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

Google フォーム

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

Google Apps Script

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

0グッド

0クリップ

投稿2023/08/04 08:11

実現したいこと

下記のサイトのようにgoogleFormの2段階の選択肢を作ろうとしています。
https://qiita.com/hayaball/items/73e99db1446cec5ca158
その際の選択肢のシートを作ろうとしています。
しかし、選択肢は増えていくので動的にする必要があります。
そこで、

A列に任意のテキストが入っています。(重複あり)
B列にも任意のテキストが入っています。
イメージ説明
これを別のシートに自動で
1行目に重複しないA列
2行目以降にA列に連動したものを入力されたいと考えました。
イメージ説明

ここに実現したいことを箇条書きで書いてください。
動的な選択肢の2段階のプルダウンのgoogleフォームの選択肢を作りたいです。

前提

googleformへの2段階式の選択肢の作り方は見つけたので、
残りは動的な選択肢を作ればよいということで、
A列が重複されずに1行目に表示され、2行目以降以降にはそのテキストが表示されるような
オリジナル関数を作成し、別シートのA1にそれを入力されれば表示されるように試みました。

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

イメージ説明

該当のソースコード

function copyUniqueTexts() { var sourceSheetName = "ユーザー"; // ここに元のシートの名前を入力してください var targetSheetName = "項目シート"; // ここに別のシートの名前を入力してください var ss = SpreadsheetApp.getActiveSpreadsheet(); var sourceSheet = ss.getSheetByName(sourceSheetName); var targetSheet = ss.getSheetByName(targetSheetName); var data = sourceSheet.getDataRange().getValues(); var uniqueContentMap = {}; // データのループを行い、重複のないA列の内容を収集 for (var i = 0; i < data.length; i++) { var content = data[i][0]; var text = data[i][1]; if (content && !uniqueContentMap[content]) { uniqueContentMap[content] = [text]; } else if (content) { uniqueContentMap[content].push(text); } } // 別のシートにデータを書き込む var targetData = []; for (var content in uniqueContentMap) { targetData.push([content].concat(uniqueContentMap[content])); } targetSheet.clear(); targetSheet.getRange(1, 1, targetData.length, targetData[0].length).setValues(targetData); }

試したこと

ChatGPTにエラーを入力し、アクセス制限も解除し、
それでもエラー内容をコピーアンドペーストしましたが
よい解決策はもらえませんでした

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答2

0

カスタム関数の中でopenByIdを使うことはできません。
対象シートの公開設定やアクセス制限の解除、appsscript.jsonへのpermission付与記述にかかわらず、カスタム関数でopenById関数を呼び出している場合、画像のようにPermission Errorになります。

カスタム関数ではなく、Apps Scriptエディタから直接copyUniqueTexts関数を実行してください。

投稿2023/08/04 10:19

編集2023/08/04 10:20
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

YAmaGNZ

2023/08/04 11:12

提示されているコードにはopenByIdは使用されていないんですよね。 なんでなんでしょ?
guest

0

ベストアンサー

まずこちらにあるように

カスタム関数がエラー メッセージ You do not have permission to call X service. をスローした場合、サービスはユーザー認証が必要なため、カスタム関数では使用できません。

カスタム関数はreturnで返す値以外にセルに影響を与えることができません。
なので、質問に書かれているような関数となると、カスタムメニューを用意し、そのメニューから実行するようにしなくてはなりません。

このことから提示されたコードの関数はreturnで値を返す必要があり、2次元配列として返せば、式を記述したセルを起点に値が入ります。
ただし、この方法でもすでに値が入っているセルに上書きすることはできません。

JavaScript

1function copyUniqueTexts(sourceSheetName) { 2 // 2次元配列の行列を入れ替える関数の定義 3 const transpose = a=> a[0].map((_, c) => a.map(r => r[c])); 4 5 var ss = SpreadsheetApp.getActiveSpreadsheet(); 6 var sourceSheet = ss.getSheetByName(sourceSheetName); 7 8 var data = sourceSheet.getDataRange().getValues(); 9 var uniqueContentMap = {}; 10 11 // データのループを行い、重複のないA列の内容を収集 12 for (var i = 0; i < data.length; i++) { 13 var content = data[i][0]; 14 var text = data[i][1]; 15 16 if (content && !uniqueContentMap[content]) { 17 uniqueContentMap[content] = [text]; 18 } else if (content) { 19 uniqueContentMap[content].push(text); 20 } 21 } 22 23 // 別のシートにデータを書き込む 24 var targetData = []; 25 for (var content in uniqueContentMap) { 26 targetData.push([content].concat(uniqueContentMap[content])); 27 } 28 29 // 行列を入れ替える 30 let retdata = transpose(targetData); 31 return retdata; 32} 33

シート1
イメージ説明

シート2
イメージ説明

投稿2023/08/04 11:09

YAmaGNZ

総合スコア10592

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

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

sloth824

2023/08/05 07:02

ありがとうございました。大変助かりました。 求めている数式が他のスプレッドシートでしたら出来、 Open By IDの原因を確認しましたら、記載してあるサイトのスプレッドシートのコピーを使用し、すでに書いてあるコードが原因だったようです。 そこの解除が未だに不明ですが、じっくり解読していきたいと思います。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問