【Excel】OFFSET関数を使った前の入力内容に応じて自動的に変わる階層型のドロップダウンリストの作り方

Excelでは階層型のドロップダウンリストを作成することもできます。階層型のリストでは、1つ前に選択したデータに応じてリストの内容を自動的に変えることができます。

たとえば、リストで都道府県に東京都を選択すると、市区町村には東京都の地名が表示されます。

千代田区を選択すると、町名では千代田区の地名が表示されるようになります。

都道府県に神奈川県を選択すると、神奈川県の市区町村が表示されるようになります。

このような階層型のリストを使うことで、長いリストからデータを探す手間を省くことができます。

目次

OFFSET関数を使った前の入力内容に応じて自動的に変わる階層型のドロップダウンリストの作り方

リストの名前の定義

まず、階層型のリストに使用するデータの一覧を用意します。今回はこのような地名のデータを用います。この際、データは1行に都道府県、市区町村、町名を入力するようにしてください。

次に各階層のリストの名前を定義します。名前を定義することで、この後数式を入力するのが楽になります。都道府県の列を選択し、数式タブの「定義された名前」から「選択範囲から作成」をクリックします。

上端行にチェックを入れた状態で「OK」を押します。

これで、都道府県のリストは「都道府県」という名前が付けられました。同じように市区町村、町名のリストにも名前を付けていきます。これで、それぞれの列に都道府県、市区町村、町名という名前が付けられました。

都道府県のリストの設定

次に入力欄にリストを設定してきます。都道府県を入力するセルにカーソルを合わせ、データの入力規則をクリックします。

リストを設定し、元の値に「=都道府県」と入力します。名前を定義しているので、これで都道府県のリスト範囲を選択していることになります。

OKを押せば、都道府県のプルダウンリストが表示されます。

市区町村のリストの設定

ここでは、いったん都道府県に「東京都」を入力した状態で、市区町村のリストを設定していきます。

先ほどと同じように入力規則でリストを選択します。市区町村のリストは都道府県名に応じて変更する必要があります。そこで、OFFSET関数を使用します。

OFFSET関数は、指定したセルを基準に、行と列を指定した数だけ移動した位置にあるセルやセル範囲を参照する関数です。

OFFSET(基準, 行数, 列数, [高さ], [幅])
指定したセルを基準に別のセル範囲を指定できる。
基準:基準となるセルまたはセル範囲を指定。
行数:基準セルから何行下に移動するかを指定。
列数:基準セルから何列右に移動するかを指定。
高さ:参照する範囲の高さを指定。
:参照する範囲の幅を指定。

元の値には以下の数式を入力します。

=OFFSET(市区町村,MATCH(A2,都道府県,0)-1,0,COUNTIF(都道府県,A2),1)

引数数式役割
基準市区町村市区町村の範囲を指定。
行数MATCH(A2,都道府県,0)-1MATCH関数を使って市区町村のリストの何行目から参照するかを選択する。MATCH関数では、指定した範囲内で特定の値を探し、その値が範囲内の何番目にあるかを返す関数。ここでは、セルA2に記載された「東京都」が都道府県のリストの何行目にあるかを検索する。東京都はリストの1行目にあるので、「1」という値を返す。
※ここで、注意が必要なのが、MATCH関数はリストの先頭行を1行目として数えますが、OFFSET関数では、基準セルから何行移動するかを指定するので、東京都の行から参照するには、行数を0としなければいけません。そのため、ここではMATCH関数の後に-1を付けて調整します。
列数0参照する範囲は市区町村の範囲で、基準から移動する必要はないため「0」を指定。
高さCOUNTIF(都道府県,A2)東京都と書かれた行の数だけ参照するので、COUNTIFを使って、東京都が書かれたセルが何行あるかを数える。
1参照する列数は市区町村の1列なので、幅には「1」を指定

これでOKを押せば、東京都に対応する市区町村のリストが表示されるようになります。

なお、都道府県の欄を空欄にした状態でリストを設定するとエラーが表示されますが、そのまま「はい」を押します。

都道府県の欄を埋めれば、同じように都道府県に対応するリストが表示されます。

町名のリストの設定

町名のリストの設定方法も基本は同じです。ここでは、いったん市区町村に「千代田区」を入力した状態で、市区町村のリストを設定していきます。

データの入力規則の元の値には以下のように数式を入力します。

=OFFSET(町名,MATCH(B2,市区町村,0)-1,0,COUNTIF(市区町村,B2),1)

引数数式役割
基準町名町名の範囲を指定。
行数MATCH(B2,市区町村,0)-1MATCH関数を使ってセルB2の千代田区が市区町村のリストの何行目にあるかを検索し、行数の調整のため「-1」を付けます
列数0参照する範囲は町名の範囲で、基準から移動する必要はないため「0」を指定。
高さCOUNTIF(市区町村,B2)千代田区と記載されたセルの行数を数えるので、COUNTIFでセルB2を条件とする。
1参照する列数は町名の1列なので、幅には「1」を指定

これで、千代田区に対応する町名が表示されるようになります。

都道府県名を神奈川県にすれば、市区町村には神奈川県に対応するものが表示され、市区町村で川崎市を選択すると、川崎市に対応する町名が表示されました。

リストにデータを追加した場合

リストに地名を追加した場合、数式タブの名前の管理からそれぞれの参照範囲を変更します。

都道府県を選択し、編集をクリックします。

参照範囲で追加された範囲も含めて選択します。

これで、リスト範囲も更新されました。同じように市区町村、町名の範囲も編集します。これで新たに追加した地名をリストとして選択できるようになります。

よかったらシェアしてね!
  • URLをコピーしました!
  • URLをコピーしました!

この記事を書いた人

Junyaと申します。都内のコンサルティングファームで働いております。まだまだ若輩者ですが、私の得た経験や感じたことを本ブログで紹介できればと思います。
Xで更新情報をお届けします。是非フォローしてください。

コメント

コメントする

目次