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

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

数値範囲で表検索する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関数の近似一致

エクセル 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近似一致の表を作成する場合の注意点

VLOOKUP関数の性質をしっかりと把握して作成します。

・検索値と一致している
・検索値を超える値が出現
・表の最下端に達した時

特に注意点としては、一致している数値があると、その行になってしまうので、
○以上~△未満
この場合は、
以上なので○と同値を、範囲の先頭列(一番左の列)に設定します。

0以上~100未満
100以上~200未満
200以上~300未満
300以上
この場合は、

エクセル VLOOKUP 近似一致

以上の数値をそのまま指定すれば良いです。

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

VLOOKUP関数に関する参考ページ

VLOOKUP関数の基本的な使い方については、
VLOOKUP関数(範囲の左端列で値検索し対応セル値)
・VLOOKUP関数の書式 ・VLOOKUP関数:近似一致(検索方法=TRUE)の使用例 ・VLOOKUP関数:完全一致(検索方法=FALSE)の使用例
こちらを参考にしてください。

以下のページも参考にしてください。
VLOOKUPを他の関数でやる方法
・VLOOKUP関数の問題点 ・解決方法 ・解決方法の具体例 ・解決方法ごとの長所短所
徹底解説(VLOOKUP,MATCH,INDEX,OFFSET)
・解説に使うシート ・VLOOKUP関数 ・INDEX関数とMATCH関数の組み合わせ ・OFFSET関数とMATCH関数の組み合わせ ・VLOOKUPを他の関数でやる方法 ・徹底解説(VLOOKUP,MATCH,INDEX,OFFSET)の最後に
【奥義】大量データでの高速VLOOKUP
・高速VLOOKUPに使用するサンプルデータ ・高速VLOOKUPの数式 ・高速VLOOKUPの数式解説 ・高速VLOOKUPの補足
ワイルドカードが使える関数
・ワイルドカードについて ・データベース関数を除くExcel2003までの関数 ・データベース関数を除くExcel2007以降 ・2020年3月現在のOffice365 ・ワイルドカードの使用例



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

SUMIF関数の良くある間違い

エクセルの関数の中で最も頻繁に使われる関数と言っても過言ではないSUMIF関数ですが、間違った指定をして、合計が合わずに悩み続けて時間を浪費してしまうことあります、そういう間違いで最も多いのが、範囲と合計範囲の指定間違いです。まずは、SUMIF関数の確認 SUMIF関数 範囲の中で、指定した条件を満たすセルの値を合…
論理式とは条件式とは(IF関数,AND関数,OR関数)
エクセルを使いこなす上で論理式はとても重要です、そもそも論理式とは何か、どうして論理式というのか、論理式の作り方、論理式の使い方について解説します。そもそも論理式という言い方が分かりずらいと思う。なぜエクセルでは論理式というのか… Microsoftのヘルプによると、IF関数 構文:IF(logical_test,
先頭の数値、最後の数値を取り出す
数値と文字が混在した文字列から、数値だけを取り出します、先頭の数値や、最後の数値だけを取り出す方法です。A1セルに 1234abcd5678 このA1セルから、1234や5678を取り出します。先頭の数値…1234 =LOOKUP(10^17,LEFT(A1,COLUMN($1:$1))*1) COLUMN($1:…
最後の空白(や指定文字)以降の文字を取り出す
いくつかのスペースやハイフンで区切られた文字列から、最後のスペースやハイフン以降の文字列を取り出します。A1セルに、abcdefghi や abc-def-ghi これらの文字列から、ghiを取り出します。以下では、見やすいように区切り文字は"-"で説明します。
SUMIFの間違いによるパフォーマンスの低下について
再計算が終わらない… そんな経験をした人は多いと思います、原因はさまざまですが、まずは数式を見直してみましょう。単純な四則演算が遅いという事はありません、それはもうPCの問題です。時間のかかる計算としては、大量データの集計計算を多数使っている場合です。
数値範囲で表検索するVLOOKUP近似一致
エクセルの日付と時刻のまとめ
・日付時刻の基本ワークシート関数 ・日付時刻の表示形式・入力規則 ・日付時刻の応用 ・マクロVBAでの日付時刻
連続数値部分を取り出し記号で連結
・作成する関数の仕様 ・スピル前:2019永続版まで ・スピル後:Office365 ・LET関数:Office365 Insider 2020年3月現在 ・関数の作成手順 ・LET関数の作成手順
指数近似/対数近似/累乗近似(掲載順位とCTR)
・Google Search Consoleから:掲載順位とCTRデータを取得 ・散布図と近似曲線 ・X軸Y軸を入れ替えて散布図を作成 ・適切な近似曲線の選択について ・指数近似を数式で求める ・関数の説明 ・掲載順位に対するCTRを求める ・指数近似/対数近似/累乗近似(掲載順位とCTR)の最後に
ジャンプ・セル選択の応用(空欄を埋める、1行置きに挿入)
ジャンプ機能は、指定のセルにジャンプする機能です。このジャンプ先の指定方法が豊富に用意されていて、その応用範囲はとても広いです。以下の2通り、・表の同上で空欄になっているセルを埋める ・表に1行おきにきに空白行を挿入する 動画と簡単な解説で紹介します。
累計を求める数式あれこれ
・例題サンプル ・SUM関数:順に足していく ・SUM関数:絶対参照と相対参照で範囲をずらす ・SUM関数:OFFSET関数で範囲をずらす ・SUM関数:INDIRECT関数で範囲をずらす ・SUMIFS関数:当該行より前の行を条件指定 ・SUM+IF関数:SUM+IFの配列数式(CSE)で ・SUMPRODUCT関数:当該行より前の行を条件指定 ・FILTER関数:当該行より前の行を条件指定 ・SUMIFS関数:スピル ・SCAN関数:LAMBDA関数内でSUM


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

ブール型(Boolean)のis変数・フラグについて|VBA技術解説(2024-04-05)
テキストの内容によって図形を削除する|VBA技術解説(2024-04-02)
ExcelマクロVBA入門目次|エクセルの神髄(2024-03-20)
VBA10大躓きポイント(初心者が躓きやすいポイント)|VBA技術解説(2024-03-05)
テンキーのスクリーンキーボード作成|ユーザーフォーム入門(2024-02-26)
無効な前方参照か、コンパイルされていない種類への参照です。|エクセル雑感(2024-02-17)
初級脱出10問パック|VBA練習問題(2024-01-24)
累計を求める数式あれこれ|エクセル関数応用(2024-01-22)
複数の文字列を検索して置換するSUBSTITUTE|エクセル入門(2024-01-03)
いくつかの数式の計算中にリソース不足になりました。|エクセル雑感(2023-12-28)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.RangeとCellsの使い方|VBA入門
4.ひらがな⇔カタカナの変換|エクセル基本操作
5.繰り返し処理(For Next)|VBA入門
6.変数宣言のDimとデータ型|VBA入門
7.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
8.並べ替え(Sort)|VBA入門
9.セルのクリア(Clear,ClearContents)|VBA入門
10.Findメソッド(Find,FindNext,FindPrevious)|VBA入門




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


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


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