エクセル関数超技
数値範囲で表検索するVLOOKUP近似一致

Excel関数の解説、関数サンプルと高等テクニック
最終更新日:2018-10-05

数値範囲で表検索するVLOOKUP近似一致

数値範囲で指定されている表を検索する場合は、VLOOKUPの近似一致を使います。


○以上~△未満、
○超~△以下、
このような数値の範囲で示されている表を検索する場合は、
VLOOKUPの近似一致を使う事で検索できます。


具体的に良くあるものとして、所得税の税率があります。

課税される所得金額 税率 控除額
195万円以下 5% 0円
195万円を超え 330万円以下 10% 97,500円
330万円を超え 695万円以下 20% 427,500円
695万円を超え 900万円以下 23% 636,000円
900万円を超え 1,800万円以下 33% 1,536,000円
1,800万円を超え 4,000万円以下 40% 2,796,000円
4,000万円超 45% 4,796,000円


所得税の累進課税の税率と控除額です。
見たことのある人も多いと思います。


所得金額が500万円なら、
「330万円を超え 695万円以下」なので、税率20%、控除額427,500円となります。

エクセルのシートで、所得金額を入力したら税率と控除額が自動的に表示されるようにVLOOKUP関数を入れたい場合を考えます。

しかし、上の表ではエクセルの関数が使えません。
エクセルの関数で使うには、「万円」といった表記は正しい数値として明式されません。
「超え 以下」は、別々の数値なので、別々のセルにする必要があります。

エクセル VLOOKUP 近似一致


このように、数値として正しく入れ直し、「超え 以下」を2列に分けています。
B列はVLOOKUP関数では使用しませんが、このようにした方が見た感じでわかり易いだろうという事で入れています。
金額なので整数という事で、「超え」の部分は+1することで対応しています。


これが出来れば、後はVLOOKUP関数で自動的に税率と控除額を取得することが出来ます。

エクセル VLOOKUP 近似一致

F1セルに所得金額を入れたら、
G1セルに税率、H1セルに控除額が表示されるようにしています。

G1セルの数式

=VLOOKUP(F2,A2:D8,3,TRUE)


H1の数式

=VLOOKUP(F2,A2:D8,4,TRUE)


VLOOKUPの書式

=VLOOKUP(検索値,範囲,列番号,検索方法)

第4引数の検索方法でTRUE(1でも良い)にするのが近似一致になります。

エクセル VLOOKUP 近似一致
エクセル VLOOKUP 近似一致

近似一致を使う場合は、検索する一番左の列は、昇順に並べられている必要があります。
昇順に並んでいないと、正しく検索されません。


VLOOKUP関数がどのように値を探しているか

検索値と完全に一致する値、または、その近似値が返されます。
完全に一致する値が見つからない場合は、検索値未満の最大値が使用されます。

少し詳しく説明すると、
範囲の先頭列(一番左の列)を上から下に向かって順に検索していきます。
・検索値と一致している
・検索値を超える値が出現
・表の最下端に達した時
いずれかの状態になった時点の行が採用されます。

検索値を3,000,000円としてみた時、
4行目の3,000,001の値が、「検索値を超える値」となるので、この行になります。
また、40,000,001以上の値を指定した時は、最終行の8行目が採用されることになります。


表を作成する場合の注意点

VLOOKUP関数の性質をしっかりと把握して作成します。
・検索値と一致している
・検索値を超える値が出現
・表の最下端に達した時

特に注意点としては、一致している数値があると、その行になってしまうので、

○以上~△未満
この場合は、
以上なので○と同値を、範囲の先頭列(一番左の列)に設定します。
0以上~100未満
100以上~200未満
200以上~300未満
300以上
この場合は、
エクセル VLOOKUP 近似一致
以上の数値をそのまま指定すれば良いです。

○超~△以下
この場合は、
超なので○よりわずかに大きい数値(整数なら+1、少数なら+0.001等)を、範囲の先頭列(一番左の列)に設定します。
前述の所得税の表がこれに該当します。



VLOOKUP関数の基本的な使い方については、
VLOOKUP関数(範囲の左端列で値検索し対応セル値)
検索値で、セル範囲の最初の列を検索し、その範囲の同じ行にある任意のセルから値を返します。Vは縦方向(vertical)の意味です、つまり縦方向の表に対して使用します。書式=VLOOKUP(検索値,範囲,列番号,検索方法) 検索値表または範囲の左端の列で検索する値を指定します。
こちらを参考にしてください。


VLOOKUPに関する参考ページ

VLOOKUPを他の関数でやる方法
VLOOKUPは便利な関数ですが以下のような問題点がある場合はこれを使うことができません 問題点 1.検索列より左側の列を取り出す場合 2.検索値が255文字を超える時 そこで他の関数でこれを実現する方法を検討します。方法1 =INDEX(範囲,MATCH(検索値,検索範囲,0),列番号) 方法2 {=IF(MIN(IF(検索範囲=検索値,

徹底解説(VLOOKUP,MATCH,INDEX,OFFSET)
検索されるキーワードで最も多いのがMATCH関数セルの範囲内で指定された項目を検索しその項目の相対的な位置を返します。セル範囲は縦方向・横方向のどちらでも指定可能です。書式MATCH(検査値,検査範囲,照合の型)検査値値(数値文字列または論理値)またはこれらの値に対するセル参照を指定できます。

【奥義】大量データでの高速VLOOKUP
大量データからのVLOOKUPを大量行に設定すると再計算がなかなか終わらなくなります… そんな経験したことがある人は、少なからずいると思います、そんな場合に、高速にVLOOKUPを実行する方法です。以下の表で説明します。※Sheet1は、A列で昇順に並び変えておきます。

ワイルドカードが使える関数





同じテーマ「エクセル関数超技」の記事

選択行の色を変える(条件付き書式,Worksheet_SelectionChange)
他ブックを参照できる関数、他ブックを参照できない関数
時間計算で困ったときの確実な対処方法
VLOOKUP 左側の列を取得(MATCH,INDEX,OFFSET)
SUMIF関数の良くある間違い
論理式とは条件式とは(IF関数,AND関数,OR関数)
先頭の数値、最後の数値を取り出す
最後の空白(や指定文字)以降の文字を取り出す
SUMIFの間違いによるパフォーマンスの低下について
数値範囲で表検索するVLOOKUP近似一致
エクセルの日付と時刻のまとめ

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

Withステートメントの実行速度と注意点|VBA技術解説(6月6日)
VBA+SeleniumBasicで検索順位チェッカー(改)|VBA技術解説(6月2日)
マクロでShift_JIS文字コードか判定する|VBA技術解説(6月1日)
Shift_JISのテキストファイルをUTF-8に一括変換|VBAサンプル集(5月31日)
「VBAによる解析シリーズその2 カッコ」をやってみた|エクセル(5月21日)
VBA+SeleniumBasicで検索順位チェッカー作成|VBA技術解説(5月18日)
テーブル操作のVBAコード(ListObject)|VBA入門(5月12日)
テーブル操作の概要(ListObject)|VBA入門(5月12日)
VBAのスクレイピングを簡単楽にしてくれるSelenium|VBA技術解説(5月6日)
Excelワークシート関数一覧(2010以降)|VBAリファレンス(4月22日)

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

1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.RangeとCellsの使い方|ExcelマクロVBA入門
4.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
5.変数とデータ型(Dim)|ExcelマクロVBA入門
6.ひらがな⇔カタカナの変換|エクセル基本操作
7.繰り返し処理(For Next)|ExcelマクロVBA入門
8.マクロって何?VBAって何?|ExcelマクロVBA入門
9.空白セルを正しく判定する方法(IsEmpty,IsError,HasFormula)|VBA技術解説
10.ExcelマクロVBAの基礎を学習する方法|エクセルの神髄



  • >
  • >
  • >
  • 数値範囲で表検索するVLOOKUP近似一致

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


    記述には細心の注意をしたつもりですが、
    間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
    なお、掲載のVBAコードは自己責任で使ってください。万一データ破損等の損害が発生しても責任は負いません。






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

    本文下部へ