【Excel】リストに追加した項目を自動的にドロップダウンリストに反映する方法

リストの項目を追加すれば、自動的にドロップダウンリストにも反映されるような仕組みの作り方を紹介します。頻繁に更新するようなリストはこの方法を使うことで、都度参照範囲を変更する手間を省くことができます。

目次

基本的なドロップダウンリストの設定方法

たとえば、このような営業記録表で会社名をドロップダウンリストから選択できるようにします。

あらかじめ顧客のリストを別のシートに作成しておきます。

次に顧客の列を選択し、データタブのデータの入力規則を開きます。

入力値の種類にリストを選択し、次の値で先ほどの顧客リストの範囲を選択します。

これでOKを押せば、ドロップダウンリストから顧客名を選択できるようになります。

しかし、この方法では顧客リストの顧客を追加しても、ドロップダウンリストには反映されません。たとえば「スイカ商事」という会社名を顧客リストの下に追加します。

しかし、ドロップダウンリストにはスイカ商事という名前は追加されていません。

入力規則のドロップダウンリストの範囲として「スイカ商事」は選択されていないからです。

テーブル機能を活用する方法

リストの追加を反映するには、テーブル機能を活用します。どこでも良いので顧客リストにカーソルを合わせ、Ctlr+Tを押します。そうすると、顧客リストの範囲を自動的に選択し、テーブルを設定してくれるので、OKを押します。

そうすると、顧客リストがテーブルになりました。

テーブルデザインのタブからテーブル名を分かりやすいものにします。ここでは、顧客リストという名称にします。

営業記録表に戻り、顧客の列を選択し、データの入力規則を開きます。入力値の種類には「リスト」を設定し、値にはINDIRECT関数を使用します。

INDIRECT関数
指定した文字列をセル参照として解釈し、そのセル参照の値を返す。

以下のように入力します。

=INDIRECT(“リスト!顧客リスト”)

「リスト」とはシート名を指し、「顧客リスト」は先ほど設定したテーブルの範囲を表しています。これで、先ほど設定した顧客リストを参照することを意味します。

この方法でリストを設定すると、今の顧客リストから顧客名を選択することができます。さらに、顧客リストの下にスイカ商事という会社を追加すると、ドロップダウンリストにも反映されます。

テーブル機能を使用しない方法

テーブル機能を使用しない方法もあります。テーブル機能ではデザインなどの柔軟性が欠けるため、使いたくないという方はこちらの方法がおすすめです。顧客の列を選択し、データの入力規則を開きます。値にはOFFSET関数を使用します。

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

ここでは、このように数式を入力します。

=OFFSET(リスト!$A$2,0,0,COUNTA(リスト!$A:$A)-1,1)

数式役割
基準顧客リストの一番上のセルA2を指定。
行数参照する範囲はセルA2を含むその下の範囲で、移動する必要はないため「0」を指定。
列数参照する範囲はセルA2を含むその下の範囲で、移動する必要はないため「0」を指定。
高さA列にデータが入力されている範囲を参照するため、COUNTA関数を使ってデータがあるセルの個数を数える。
A列の1列だけを参照するため、「1」と入力。

この方法でドロップダウンリストを設定すれば、今の顧客リストからも選択でき、顧客リストの新しい顧客名を追加してもドロップダウンリストに反映されます。

基本的にはテーブルの方が簡単ですが、テーブルを使用したくない場合はこの方法で、自動的に更新されるドロップダウンリストを作成することができます。

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

この記事を書いた人

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

コメント

コメントする

目次