エクセル雑感
VLOOKUPを使うことを基本としてシートを設計すべきか

ExcelマクロVBAとエクセル関数についての私的雑感
公開日:2021-08-17 最終更新日:2021-08-17

VLOOKUPを使うことを基本としてシートを設計すべきか


これはツイッターで、VLOOKUPを使うことを基本としてシートを設計すべきかどうかについて連続ツイートしたものをまとめたものです。
下書きもなく、深夜に思うがままにツイートしたので、論理的に細かいところや話のつながりについてはご容赦ください。



ツイート

VLOOKUPを使うことを基本としてシートを設計すべきかどうか。
基本はそれで良いと思います。
つまり、左端にキーを置くという事です。
キーでVLOOKUPするという事です。
しかし、それだけでは済まないことが結構あるから問題がでてきます。


このような話において良く例に出されるのが、
「名前で検索したい」というもの。
番号,名前,その他
番号でVLOOKUPは良いが名前で引けない。
なら、最初からINDEX+MATCHだけでやったほうが良いというもの。


ではお聞きしたい。
名前で引くという事は、「名前」をデータとして入れるという事ですよね。
名前を手打ちするのですか?
どうやって「名前」をいれるのでしょうか?


ここから考える必要があるという事です。
「名前」は入力規則のリストなりで入れるのではないのでしょうか?
というか、そうしなかったら表記揺れでVLOOKUPがどうのという以前の話になってしまいます。
では、「名前」だけのに入力規則で良いのでしょうか?


同姓同名がいないのでしょうか?
表示はあいうえお順ですか、番号順ですか?
ここから考えていくという事です。
同姓同名がいるなら、単に正式な氏名欄とは別のリスト用の列が必要になりますよね。
順番を意識するなら、別のシートなりに並べ替える必要がありますよね。
どうするんでしょうか?


同姓同名対策としてリスト用に別列を持つのなら、そこに番号も含めておけばよいです。
名前:番号
このリストから選択した番号でVLOOKUPできます。
並べ替えについては、従来はどうしようもなかったのですがSORTが実装された後では別シートに並べ替えて、そのシートで同姓同名の対策をすれば良いです。


この方法が良いといっているわけではありません。
一つの方法として言っているものです。
業務によって最適な手段は変わります。

言いたいのは、こういうことを考えるのがシート設計だという事です。


シートのデータはデータベースだという意見があります。
その用途で貯めたデータは確かにデータベースでしょう。
さらに、見た目的にはRDBと見なすこともできそうにも見えます。
ここに勘違いがある気がします。
RDBではないのだから、通常のデータベース設計は適用できません。


RDBなら、そもそも列順などほとんど意味を持ちません。
慣用的な使い方はあっても、それが規則と言う程のものではありません。
ではエクセルのシートとRDBのテーブルの違いは何かというと、生のデータを目で見る事が普通にあるのかと言う事です。


RDBの生のテーブルをそのまま見るのは開発者だけでしょう。これは論ずる必要がないですね。
ユーザーは何らかのソフトを通してしか見ないので、テーブル上の列順は意識する必要が無いのです。
しかしエクセルは違います。
ユーザーが生データをそのまま見るし、場合によっては直接変更を加えます。


だから難しいのです。
RDB設計とは違った難しさがでてきます。
単純な話をしたら、全てVBAでしか扱わないようにした場合は、シートの列順はどうでも良いのです。
入力はフォームまたは別シートで行い、データベースのシートに転記するなら、これはもうRDBとほぼ同じ考え方で良いです。


つまり問題は、VBAを使わずに関数を主体としてシステム構築する場合です。
この場合、作成者または改修者がプロだけではないと考えるべきでしょう。
そこで、ではどうしたら分かり易くなるかを考える事になります。
ここが難しい、分かり易くすっきりしたデータ…これは極めて難しい。


こういうことを考えた時、従来までなら左端にキーを置いてVLOOKUPを主体に作成していく。
こういう手法が分かり易かったという事です。
もちろん、シートによっては、検索するものによっては例外も出てくるのでINDEX+MATCHは必須です。
しかしそれはむしろ例外くらいの位置づけが良いという事です。


下書きもなく、いきなりツイート始めたので、とりとめのない話になってますが、あくまで従来の手法として、分かり易く簡単な作りとしての基本はVLOOKUPだという事です。
しかし365も普及してきていて、そうなればXLOOKUPも使えることですし、それぞれで工夫していけば良いと思います。


そもそもなぜこんなツイートを始めたのかもよく分からなくなってきたので、この辺りでお終いとします。
システムは生き物ですので、生息場所によって様々な進化を遂げるものです。
適者生存です。
環境に合ったシステムはきっと生き残るはずですし、合わなければ消えていくことになるはずです。完




同じテーマ「エクセル雑感」の記事

在庫を減らせ!毎日棚卸ししろ!
エクセル馬名ダービー
VBA学習のお勧めコース
コンピューターはブラックボックスで良い
VLOOKUPを使うことを基本としてシートを設計すべきか
VBAマクロと操作対象データの分離について
IF関数の論理式で比較演算子を省略したCOUNT系関数を書くのは
VBAでの式と文の違い
電卓とプログラムと私
「緩衝材」としてのVBAとRPA|その終焉とAIの台頭
開いている「Excel/Word/PowerPoint」ファイルのパスを調べる方法


新着記事NEW ・・・新着記事一覧を見る

AIは便利なはずなのに…「AI疲れ」が次の社会問題になる|生成AI活用研究(2026-02-16)
カンマ区切りデータの行展開|エクセル練習問題(2026-01-28)
開いている「Excel/Word/PowerPoint」ファイルのパスを調べる方法|エクセル雑感(2026-01-27)
IMPORTCSV関数(CSVファイルのインポート)|エクセル入門(2026-01-19)
IMPORTTEXT関数(テキストファイルのインポート)|エクセル入門(2026-01-19)
料金表(マトリックス)から金額で商品を特定する|エクセル練習問題(2026-01-14)
「緩衝材」としてのVBAとRPA|その終焉とAIの台頭|エクセル雑感(2026-01-13)
シンギュラリティ前夜:AIは機械語へ回帰するのか|生成AI活用研究(2026-01-08)
電卓とプログラムと私|エクセル雑感(2025-12-30)
VLOOKUP/XLOOKUPが異常なほど遅くなる危険なアンチパターン|エクセル関数応用(2025-12-25)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.日本の祝日一覧|Excelリファレンス
3.変数宣言のDimとデータ型|VBA入門
4.FILTER関数(範囲をフィルター処理)|エクセル入門
5.RangeとCellsの使い方|VBA入門
6.繰り返し処理(For Next)|VBA入門
7.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
8.マクロとは?VBAとは?VBAでできること|VBA入門
9.セルのクリア(Clear,ClearContents)|VBA入門
10.メッセージボックス(MsgBox関数)|VBA入門




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。
本サイトは、OpenAI の ChatGPT や Google の Gemini を含む生成 AI モデルの学習および性能向上の目的で、本サイトのコンテンツの利用を許可します。
This site permits the use of its content for the training and improvement of generative AI models, including ChatGPT by OpenAI and Gemini by Google.



このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ