*When you need to find data in your sheet that corresponds to a certain key record, it is usually Google Sheets VLOOKUP you turn to. But there you go: VLOOKUP slaps you with limitations almost immediately. That's why you'd better increase the resources for the task by learning INDEX MATCH.*

INDEX MATCH in Google Sheets is a combination of two functions: INDEX and MATCH. When used in tandem, they act as a better alternative for Google Sheets VLOOKUP. Let's find out their capabilities together in this blog post. But first, I'd like to give you a quick tour of their own roles in spreadsheets.

I'd like to start with Google Sheets MATCH because it's really simple. It scans your data for a specific value and returns its position:

=MATCH(search_key, range, [search_type])

*search_key*is that record you're looking for. Required.*range*is either a row or a column to look in. Required.**Note.**MATCH only accepts one-dimensional arrays: either row or column.*search_type*is optional and defines if the match should be exact or approximate. If omitted, it is 1 by default:*1*means the range is sorted in ascending order. The function gets the largest value less than or equal to your*search_key*.*0*will make the function look for the exact match in case your range is not sorted.*-1*hints that records are ranked using descending sorting. In this case, the function gets the smallest value greater than or equal to your*search_key*.

Here's an example: to get a position of a certain berry in the list of all berries, I need the following MATCH formula in my Google Sheets:

`=MATCH("Blueberry", A1:A10, 0)`

While MATCH shows where to look for your value (its location in the range), Google Sheets INDEX function fetches the value itself based on its row and column offsets:

=INDEX(reference, [row], [column])

*reference*is the range to look in. Required.*row*is the number of rows to offset from the very first cell of your range. Optional, 0 if omitted.*column*, just like*row*, is the number of offset columns. Also optional, also 0 if omitted.

If you specify both optional arguments (row and column), Google Sheets INDEX will return a record from a destination cell:

`=INDEX(A1:C10, 7, 1)`

Skip one of those arguments and the function will get you the entire row or column accordingly:

`=INDEX(A1:C10, 7)`

When INDEX and MATCH are used together in spreadsheets, they are at their mightiest. They can absolutely substitute Google Sheets VLOOKUP and fetch the required record from a table based on your key value.

Suppose you'd like to get the stock info on cranberry from the same table I used above. I only swapped columns B and C (you'll find out why a bit later).

- Now all berries are listed in column C. Google Sheets MATCH function will help you locate the exact row of the cranberry:
*8*`=MATCH("Cranberry", C1:C10, 0)`

- Put that whole MATCH formula to a
*row*argument in the INDEX function:`=INDEX(A1:C10, MATCH("Cranberry", C1:C10, 0))`

This one will return the entire row with cranberry in it.

- But since all you need is the stock info, specify the number of the lookup column as well:
*3*`=INDEX(A1:C10, MATCH("Cranberry", C1:C10,0), 2)`

- Voila!

- You can go further and give up that last column indicator (
*2*). You won't need it at all if you use only the lookup column (*B1:B10*) rather than the entire table (*A1:C10*) as the first argument:`=INDEX(B1:B10, MATCH("Cranberry", C1:C10, 0))`

**Tip.**A more convenient way to check the availability of various berries would be to place them in a drop-down list (*E2*) and refer your MATCH function to the cell with that list:`=INDEX(B1:B10, MATCH(E2, C1:C10, 0))`

Once you select the berry, the related value will change accordingly:

You already know that Google Sheets INDEX MATCH looks your value up in a table and returns another related record from the same row. And you know that Google Sheets VLOOKUP does exactly the same. So why bother?

The thing is, **INDEX MATCH** has **some major advantages** over VLOOKUP:

**Left-side lookup is possible**. I changed the columns places earlier to illustrate this one: INDEX MATCH function in Google Sheets can and does look to the left of the search column. VLOOKUP always searches the very first column of the range and looks for matches to its right — else, it gets only #N/A errors:

**No messed up references when adding new columns and moving existing ones.**If you add or move columns, INDEX MATCH will reflect the changes automatically without meddling in the result. Since you use column references, they are instantly adjusted by Google Sheets:

Go ahead and try to do this with VLOOKUP: it requires the order number rather than cell references for a lookup column. Thus, you'll just end up getting the wrong value because another column takes the same place — column*2*in my example:

**Considers text case**when necessary (more on this right below).- Can be used for vertical lookup based on multiple criteria.

I invite you to look at the last two points in detail below.

INDEX MATCH is a go-to when it comes to case-sensitivity.

Supposing all berries are being sold in two ways — loose (weighed at the counter) and packed in boxes. Hence, there are two occurrences of each berry written in different cases in the list, each with its own ID that also vary in cases:

So how can you look up the stock info on a berry sold in a certain way? VLOOKUP will return the first name it finds no matter its case.

Luckily, INDEX MATCH for Google Sheets can do it correctly. You'll just need to use one additional function — FIND or EXACT.

FIND is a case-sensitive function in Google Sheets which makes it great for case-sensitive vertical lookup:

`=ArrayFormula(INDEX(B2:B19, MATCH(1, FIND(E2, C2:C19)), 0))`

Let's see what happens in this formula:

- FIND scans column C (
*C2:C19*) for the record from*E2*(*cherry*) considering its letter case. Once located, the formula "marks" that cell with a number —*1*. - MATCH searches for this mark —
*1*— in the same column (*C*) and hands the number of its row to INDEX. - INDEX comes down to that row in column B (
*B2:B19*) and fetches the required record to you. - When you finish building the formula, press Ctrl+Shift+Enter to add ArrayFormula at the beginning. It is required because without it FIND won't be able to search in arrays (in more than one cell). Or you can type '
*ArrayFormula*' from your keyboard.

If you replace FIND with EXACT, the latter will look for records with the exact same characters, including their text case.

The only difference is that EXACT "marks" a match with *TRUE* rather than number *1*. Hence, the first argument for MATCH should be *TRUE*:

`=ArrayFormula(INDEX(B2:B19, MATCH(TRUE, EXACT(E2, C2:C19), 0)))`

What if there are several conditions based on which you'd like to fetch the record?

Let's check the price of the *cherry* that is being sold in *PP buckets* and is already *running out*:

I arranged all the criteria in the drop-down lists in column F. And it is Google Sheets INDEX MATCH that supports multiple criteria, not VLOOKUP. Here's the formula you will need to use:

`=ArrayFormula(INDEX(B2:B24, MATCH(CONCATENATE(F2:F4), A2:A24&C2:C24&D2:D24, 0),))`

Don't panic! :) Its logic is actually quite simple:

*CONCATENATE(F2:F4)*combines all three records from cells with criteria into one string like this:*CherryPP bucketRunning out*This is a

*search_key*for MATCH, or, in other words, what you're looking for in the table.*A2:A24&C2:C24&D2:D24*constitute a*range*for the MATCH function to look in. Since all three criteria take place in three separate columns, this way you kind of combine them:*CherryCardboard trayIn stock*

*CherryFilm packagingOut of stock*

*CherryPP bucketRunning out*

etc.- The last argument in MATCH —
*0*— makes it possible to find the exact match for*CherryPP bucketRunning out*among all those rows of combined columns. As you can see, it's in the 3rd row. - And then INDEX does its thing: it fetches the record from the 3rd row of column B.
- ArrayFormula is used to allow other functions to work with arrays.

`=IFERROR(ArrayFormula(INDEX(B2:B27, MATCH(CONCATENATE(F2:F4), A2:A27&C2:C27&D2:D27, 0),)), "Not found")`

Whatever lookup function you prefer, VLOOKUP or INDEX MATCH, there's a better alternative to them both.

Multiple VLOOKUP Matches is a special add-on for Google Sheets designed to:

- lookup without formulas
- lookup in all directions
- search by multiple conditions for different data types:
*text, numbers, dates, time,*etc. - fetch several matches, as many as you need (providing there are as many of them in your table, of course)

The interface is straightforward, so you won't have to doubt whether you're doing everything correctly:

- Select source range.
- Set the number of matches and columns to return.
- Fine-tune the conditions using the predefined operators (
*contains, =, not empty*,*between*, etc.).

You will also be able to:

- preview the result
- decide where to place it
- and how: as a formula or just values

Don't miss out on this opportunity to check the add-on. Go ahead and install it from Google Workspace Marketplace. Its tutorial page will explain every option in detail.

We also prepared a special instructional video (look for its transcript in this blog post):

See you in the comments below or in the next article ;)

Excel formulas
CSV
Excel functions
Print
Financial functions
Vlookup
Merge data in Excel
SumIf
CountIf
Excel Compare
If statement
Excel Charts
Pivot Table
Conditional formatting
Excel formatting
Excel duplicates
Excel date
Excel tips
Excel macro
Outlook
Google Sheets
Outlook duplicates
Shared email templates

Category: Google Sheets Tips

## 32 responses to "INDEX MATCH in Google Sheets – flexible Vlookup for your spreadsheets"

Hi Sir

Thanks for your very usefull tutorial.

I need your help in very small thing. I am converting a simple formula into array formula but its not working form me for some reason.

Normal formula is =IF(AND(A3<'IIR & NPV - Calculation Dashboard'!$B$2,OR(A3=1,A3=13,A3=25,A3=37,A3=49)),'IIR & NPV - Calculation Dashboard'!$B$12,0)

Its Working as expected for me. But when I am converting it into Array formula, it looks like this

=ArrayFormula(IF(AND(A3:A<'IIR & NPV - Calculation Dashboard'!$B$2,OR(A3=1,A3=13,A3=25,A3=37,A3=49)),'IIR & NPV - Calculation Dashboard'!$B$12,0))

It is not giving me the same result as its normal formula.

Can you please help me out here and tell me what is the error in this array formula?

Hello!

If I understand your task correctly, the following formula should work for you:

=ArrayFormula(IF(IF(A3:A20 < $B$2,TRUE,FALSE) * (IF(A3:A20=1,TRUE,FALSE)+ IF(A3:A20=13,TRUE,FALSE)+ IF(A3:A20=25,TRUE,FALSE)+ IF(A3:A20=37,TRUE,FALSE)+ IF(A3:A20=49,TRUE,FALSE)),$B$12,0))

Please adjust this formula according to your data if needed.

Help! I have two sheets: MasterSheet and Operations Sheet.

I need to replicate Columns H and I on the MasterSheet has two columns (H and I) in the Operations Sheet in Column C (which corresponds to Column H on the MasterSheet) and Column D (which corresponds to Column I on the MasterSheet).

I need a formula where Column D will automatically populate with the cell value in Column I on the MasterSheet if the value in Column C matches the value in Column H of the MasterSheet. Essentially, if Column H and C are the exact match, then Column D should populate with the value in Column I in the same Row as Column H.

Hello Elsa,

I'm really sorry but your description is not clear.

For me to be able to suggest you anything, please try to specify (consider bulleted list) what columns each sheet contains exactly and what data should be pulled and where exactly. Thank you.

I have a Worksheet with 2 tabs.

The first tab is named MasterSheet.

- Column H heading on the MasterSheet is called "Purchase Req"

- Column H on the MasterSheet is called "Purchase Order"

The second tab is named OperationsSheet

- Column C heading on the OperationsSheet is called "Purchase Req"

- Column D heading on the OperationsSheet is called "Purchase Order"

I need a formula for Column D on the Operations Sheet that:

1) Searches column C on the Operations Sheet for an exact match as that in Column H of the MasterSheet

2) If it finds the exact match, Column D in the OperationsSheet will then return (or copy) the value found in Column I of the MasterSheet.

Example:

MasterSheet OperationsSheet

H I C D

PR PO# PR PO#

1234 450001234 6738 450089628

6738 450089628 1234 450001234

Thank you very much for the detailed explanation, Elsa!

Now I've got your task. Here are the formulas for you to try (assuming there are 10 rows in a table, so please adjust the number 10 to your number of rows):

=INDEX('Master Sheet'!I1:I10, MATCH(C2, 'Master Sheet'!H1:H10, 0))

=ARRAYFORMULA(VLOOKUP(C2:C10, 'Master Sheet'!H2:I10, 2))

Number 2 here is the number of the column I in my small table. Please also change it to yours.

Hope this helps!

Thank you, this is very helpful! One last question, how do you add to the first formula to replace the #N/A error with a blank cell if the searched value is not found?

You're most welcome, Elsa!

As for you question, whatever formula you choose, just wrap it in IFERROR as described here.

Hi I have 3 sheets

One name "Draw Results" Contains numbers e.g. 002345

(numbers are filled on the entire sheet e.g. 'Draw Results' A1:K159)

Second Named "Bond List" Contains numbers e.g. 002347

(numbers are filled on the entire sheet e.g. 'Bond List' A1:K159)

Third Named "Matched Results" want the matched results displayed in here.

What Formula do I put in here I have tried =INDEX('Draw Results'!$A$1:$A$159,MATCH('Bond List'!A1,'Bond List'!$A$1:$A$175,0),1)

Please help

Thank You

Hi Frais,

For me to be able to help you, please specify whether you're trying to compare two sheets for duplicates or find matching data between two columns in two sheets and pull the corresponding data from some other column.

How to return multiple search results using index match? The Aggregate function of excel does not work

Hello John,

Do you need to return multiple matches in rows or columns? What formula are you trying to use in Google Sheets exactly?

Hello, I hope you're fine.

I have an issue on Gsheet in a INDEX(MATCH formulae.

First, I get value (invoice's numbers) from differents sheets with a filter formulae.

Secondly, I have to make an INDEX(MATCH of these values with an extraction of my accounting software.

I don't know why, the return is "Did not find value '2020026' in MATCH evaluation." but, when I use ctrl + f, I find this value in my extraction.

For your information, my formulae is juste below :

=IFERROR(

IF(A2="";"";

IF(INDEX('COMPTA 2000150200'!$A:$A;MATCH(A2;'COMPTA 2000150200'!$A:$A;0);1)=A2;"OK";"NOK"))

;"NOK")

A2 was get by filter function. But when I replace "A2" by the invoice number (2020026), it's works !

Can you help me please ?

Thanks in advance,

Regards.

Hello Corentin,

Please double-check the format of the values returned by FILTER and of the value in A2 which is used in MATCH. If they differ, this can cause difficulties.

If this is not your case, please consider sharing an editable copy of your spreadsheet with us (support@apps4gs.com). I kindly ask you to shorten the tables to 10-20 rows.

Note.We keep that Google account for file sharing only, please do not email there. Once you share the file, just confirm by replying here.We'll look into it and see what may be causing difficulties.

great tutorial. thank you so much!

I need to match with max of col index in google sheet. But couldnot able to acheive it

Eg. Col A has 10 prod codes (may repeat many rows)

Have to match with max of col B values respectively

Product Code Test %

A 50

B 55

A 70

In the above case if I filter A, then the restult should be MAX(50, 70)which is 70

Hello Saravana,

If I understand your task correctly, the MAXIFS function may help you. It returns the maximum value from one column based on the condition in another column. For you it may look like this:

=MAXIFS(B2:B10,A2:A10,"A")

If you mean something different, please describe your task in more detail.

Hello, firstly i'd like to say thank you for all the guides, they have really helped!

So I have one sheet with 2 tabs on it. First is called "Items" and second is called "Master".

Here is the simplest way to describe what I need:

Reference: Items!A:A (List of unique ids)

Look here for a match: Master!C:C (List of ids, some repeated)

Return: Master!B:B (info to go with the ids)

Into: Items!G:G (results need to be in one cell and separated by commas)

The tricky thing is there may be any number of matches in Master!C:C from 0 upwards, and I need all of them except the first one since that one is different and I already have that in Items!E:E. If there are no matches it stays blank.

I am currently using this formula to get the first match in Items!E2, but I don't know how to adapt it for the rest of the matches and exclude the first to go in Items!G2.

=IFERROR(INDEX('Master'!$B:$B, MATCH ($A2, 'Master'!$C:$C, 0)))

Hello!

Unfortunately, without seeing your data it hard to give you advice.

For me to be able to help you better, please describe your task in more detail. Please specify what you were trying to find, what formula you used and what problem or error occurred.

Give an example of the source data and the expected result.

It’ll help me understand it better and find a solution for you. Thank you.

Sorry about that, I couldn't come up with a better way to explain (it already took me an hour to write the question the first time). It also turns out I didn't need to cut off the first match, so that made it a lot simpler and I ended up using FILTER like this instead:

=IFERROR(CONCATENATE("{ ",JOIN(", ",UNIQUE(FILTER('Master'!$B:$B , 'Master'!$C:$C = $A2 ))," }")))

Unfortunately I still can't figure out how to sort the results by 'Master'!$A:$A but it's getting there...

Thank you for trying to help anyway.

Hello!

Correct your formula to write your search results on a single line.

=IFERROR(CONCATENATE("{ ",TEXTJOIN(", ",TRUE,UNIQUE(FILTER(Master!$B:$B, Master!$C:$C = $A2))," }")),"")

If you have any questions, don't hesitate to ask.

Thanks, I didn't know TEXTJOIN was a thing since I always get the same result, but I guess there wil be times when it matters so it's good to know.

Do you know how I can get the results in alphabetical order of Master!$A:A without having to sort that sheet manually?

I can only figure out how to use SORT to get the results in alphabetical order of themselves (Master!$B:B) which is no use to me.

Hello!

I am not sure I fully understand what you mean. You have not used the link Master!$A:A. Please specify what you were trying to find.

Currently the results are in the same order as they appear on the Master tab but I cannot rely on people to remember to sort that tab alphabetically by column A manually after adding things to it.

Since I am taking results from Master column B instead of Master column A I can't figure out how to use SORT on the results without sorting them alphabetically according to column B which is not what I want. I need the results to be appear as if Master tab had been sorted alphabetically by Master column A before the formula was applied, even though it is not.

Nevermind I figured it out. Also TEXTJOIN didn't work but JOIN does. Thanks very much for your time and trying to help though! Sorry I cannot explain things clearly.

Apologies TEXTJOIN does work when I remembered to put TRUE in. Thanks!

Hi, Thank you for the very thorough instructions. I am wondering how the below formula can be converted to use the match function to replace the Vlookup Index number. I have tried but I can't seem to get the correct result.

Current working formula =SUMIF(VLOOKUP(A20,'Sales Comp GBP'!$F$2:$CC$1000,48,false),"#N/A")

Tried- =SUMIF(VLOOKUP(A20,'Sales Comp GBP'!$F$2:$CC$1000,MATCH("MTD_net_pub_comp",'Sales Comp GBP'!1:1,0),false),"#N/A")

This formula doesn't seem to bring back the same result. do you know why this could be the case

Hi Rob,

I am a bit surprised your first SUMIF works since its VLOOKUP returns one value rather than an array, so there's nothing to sum.

Would it be possible for you to create a shortened version of your spreadsheet along with a formula and share it with us? It's support@apps4gs.com.

Note.We keep that Google account for file sharing only, please do not email there. Once you share the file, just confirm by replying here.I made a sheet with 220 sheets(tabs), i used " iferrrorarrayvlookup" 300 times, and two master sheets(all tabs data at once by formul eg: "{a!A1:Z75;.......}), And i used one now formula, which is linked to all sheets,

present problem is: its taking load for 2 min when i open in android or pc what is the reason of it ?

Hello Shravan,

There are lots of things that can impact Google Sheets speed. But I believe the answer is in your question :) It takes time for Google Sheets to load the data returned by the array formula that refers to other hundreds of formulas that, in their turn, reference hundreds of sheets. Try splitting the data into separate spreadsheets and/or reference fewer data in formulas.

how can I import a range from a different gsheet into the INDEX formula

i tried =index(importrange("URL","Sheet1!B2:G1285"),MATCH(G3,B2:B1285,0))

and i got this error: Circular dependency detected. To resolve with iterative calculation, see File > Spreadsheet Settings.

Hello Melissa,

The 'circular dependency' error means that your formula refers to a range that contains the formula itself. Just put it in another cell outside the range you refer to or change the ranges inside the formula.