【Spread Sheat】2つのプルダウンリスト連動させ、これを複数行に渡って設置したい。

やりたいこと

以下の動画のように、一つ目のプルダウンの選択内容に応じて二つ目のプルダウンの候補値が動的に変化する状態を目指します。これを複数行に渡って設置します。

以下の例では、一つ目のプルダウンで「あ行」を選択した場合には二つ目の候補が「あいうえお」、「か行」を選択した場合には「かきくけこ」となっています。

https://i.gyazo.com/84dc52c89842771f0891f4160d452f28.gif

STEP 1. 候補となる元データを準備する

入力用シートとは別に新たなシートを作成し、候補となるデータを以下のように準備します。下記例ではこのシートに「マスタ」という名称を付けています。

https://i.gyazo.com/176663653df7f508079d0db427be4a6e.png

STEP 2. プルダウンの参照用シートを作成する

新しいシートを作成して準備を進めていきます。ここではこのシートに「プルダウン候補」という名称を付けます。

2-1. 第一プルダウンの候補を引っ張る

一つ目のプルダウンの候補となる行データをマスタからこのシートに引っ張ってきます。

以下の関数を使います。

  • UNIQUE: 値が重複しないように参照する
  • IFERROR: 空白行を取り除く
  • TRANSPOSE: 行方向(縦方向)に取得される候補を列方向(横方向)に転置する

具体的には、「プルダウン候補」シートの A1 セルに次の式を入力します。

1=TRANSPOSE(IFERROR(UNIQUE('マスタ'!A2:A)))

https://i.gyazo.com/323084603ed20c117fefdd5820a78822.png

2-2. 第二プルダウンの候補を引っ張る

一つ目のプルダウンの候補の下に第二プルダウンの候補を表示します。

以下の関数を使います。

  • QUERY: キーが一致する行を複数取得する(VLOOKUP の複数行取得版)

具体的には、「プルダウン候補」シートの A2 セルに次の式を入力します。

1=QUERY('マスタ'!$A:$B, "select B where A = '"&A1&"'")

https://i.gyazo.com/1d975a98ec9c290bfe7e652d2640706b.png

「あ行」の候補が表示できたら、A2 セルをドラッグして「わ行」までデータを埋めます。

https://i.gyazo.com/f67a4e1bff376069ab32deb3ff2b9551.png

2-3. 名前付き範囲の定義をする

各行ごとに名前付き範囲を定義していきます。

まずは「あ行」の名前付き範囲を定義します。名前付き範囲を定義するには次の手順で操作します。

  1. A2-A6 セルをドラッグして範囲選択する
  2. 選択範囲の上で右クリック
  3. 「セルでの他の操作項目を表示」にマウスホバー
  4. 「名前付き範囲を定義」をクリック
  5. 範囲の名前に「あ行」と入力

https://i.gyazo.com/79fa32e3f646974fa6dc00cd897d871d.png

「あ行」が完了したら、同様の手順で「わ行」まで名前付け範囲を定義します。

STEP 3. 入力用シートにプルダウンを設置する

3-1. 一つ目のプルダウンを設置する

まずは A2 セルにデータの入力規則を設定します。次の手順で操作します。

  1. 入力用シートを選択する
  2. A2 セルで右クリック
  3. [セルでの他の操作項目を表示] > [データの入力規則]
  4. 「条件」に「リストを範囲で指定」を設定
  5. 範囲に「=‘プルダウン候補’!$1:$1」を入力
  6. 「保存」

https://i.gyazo.com/168fb4f59b4b826f5b5f0c16fd1fcfd0.png

https://i.gyazo.com/7f9aab39be3e88e56a64c80692831910.png

3-2. 一つ目のプルダウンの値に応じた候補を取得する

C2 セルに次の関数を入力します。

1=IFERROR(TRANSPOSE(INDIRECT(A2)))

INDIRECT 関数を使用して名前付き範囲を参照することで、一つ目のプルダウンの値に応じて候補を動的に取得することができます。

https://i.gyazo.com/b393251f5620eda4336e4c9937a7f371.png

3-3. 二つ目のプルダウンを設置する

  1. B2 セルを右クリック
  2. [セルでの他の操作項目を表示] > [データの入力規則]
  3. 「条件」に「リストを範囲で指定」を設定
  4. 範囲に「=C2:2」を入力
  5. 「保存」
  6. 再度 B2 セルを右クリック
  7. [セルでの他の操作項目を表示] > [データの入力規則]
  8. 範囲が「=$C$2:$2」に自動で変換されている場合には「=C2:2」に修正する
  9. 「保存」

https://i.gyazo.com/4d209391e1a286559a771890b5ff6b45.png

3-4. オートフィルで関数をコピーする

  1. A2:C2 をドラッグで範囲選択
  2. 選択範囲を下方向にドラッグして関数をコピー

https://i.gyazo.com/287cca8bf6d5634b976b852ba75fa8fa.png