VLOOKUP - Exact Match & Approximate Match
Excel Tip #013
VLOOKUP - Exact Match & Approximate Match
In the previous tip #012 (VLOOKUP & INDEX + MATCH), we learnt about VLOOKUP, it's syntax and how to use it. We also learnt about its drawback and how INDEX & MATCH can be helpful.
Like said in the previous tip, there are 2 match option available in VLOOKUP - Exact & Approximate Match. Let us first refresh the syntax of VLOOKUP.
Like said in the previous tip, there are 2 match option available in VLOOKUP - Exact & Approximate Match. Let us first refresh the syntax of VLOOKUP.
Syntax: =VLOOKUP(lookup_value, table_array, col_index_num, [range_lookup])
In simple terms,
= VLOOKUP(value/data that is used as reference, data table, the column # where our resultant data resides, exact (or) approximate match)
Let's have a closer look at the last argument you supply to the Excel VLOOKUP function - range_lookup. You are likely to get different results in the same formula depending on whether you enter TRUE or FALSE (Approximate or Exact).
The first thing you need to do is sort the first column in your lookup range in ascending order. This is very important because your VLOOKUP formula is going to return the next largest value for the lookup value you specify and then stop searching.
If you neglect to sort your data properly, you will end up having really strange results or #N/A error.
Below is an example to see the closest rank to rank 10.
You can see rank 11 is available but the resultant shows rank 7. This is because the VLOOKUP function with approximate match returns the next largest value that is less than the lookup value.
Some more examples:
Did you the second question, to find the Sales rep who ranked 13? As highlighted in the image, there are 2 Sales Rep who are ranked 13, Bessie and Horace but the final result shows Horace. Why?
This is because when we use Approximate match, VLOOKUP will look for all matches of ranked 13 and will fill in the later part by overwriting if it has found already.
If using Exact match for rank 13, you will see Bessie as the result. This is because Exact match will display the first found solution.
This is a difference when using Exact Match & Approximate Match in VLOOKUP.
- If range_lookup is set to FALSE, the formula searches for exact match, i.e. for the lookup value exactly as you've entered it in the first parameter (lookup_value )
- If there are two or more values in the first column of table_array that match the lookup value, the 1st value found is returned. If an exact match is not found, the #N/A error is returned
- For example, if you use the formula =VLOOKUP(4, A2:B15,2,FALSE), but your data does not contain value 4 in cells A2 through A15, the formula will return #N/A
- If range_lookup is set to TRUE or omitted, the formula searches for approximate match. More precisely, your VLOOKUP formula will search for an exact match first and if an exact match is not found, it will return an approximate match. An approximate match is the next largest value that is less than lookup_value.
VLOOKUP with approximate match:
Consider the below example, Rank and Sales Rep.Example - VLOOKUP, Approximate match |
If you neglect to sort your data properly, you will end up having really strange results or #N/A error.
Sort data to use Approximate match in VLOOKUP |
Use of Approximate match, rank closes to rank 10 |
Some more examples:
Some more examples - VLOOKUP with Approximate Match |
This is because when we use Approximate match, VLOOKUP will look for all matches of ranked 13 and will fill in the later part by overwriting if it has found already.
If using Exact match for rank 13, you will see Bessie as the result. This is because Exact match will display the first found solution.
This is a difference when using Exact Match & Approximate Match in VLOOKUP.
Comments
Post a Comment