As I previously discussed, Excel provides many useful ways to automatically compare two lists of data or information. In our other example we compared two lists of four digit account values; for this example we’ll compare two lists of names.
You and a friend are throwing an epic party and have each maintained separate guest lists to track who’s coming. After a few weeks you decide to compare both lists to make sure everyone on your friend’s list (List B) is also on your list (List A).
How to do it
- Arrange the lists in two columns with List A in column A and List B in column B.
- Create a third column in column D called List C (leave column C blank for easier readability).
- In cell D5 enter the formula:
=IF(COUNTIF(B:B,A5),A5,0)
and press Enter. - Select cell D5 and navigate to Home → Conditional Formatting → Highlight Cell Rules → Equal To…
- In the Equal To dialog box, type 0 and click OK.
- Select cell D5 down to the end of the lists and press Ctrl+D to copy the formula and conditional formatting down.
The Result
A name in List C means the corresponding name from List A was also found within List B. In the screenshot above, cell D5 displays the “Moon Barrientos,” which means that name was found on both List A and B. On the other hand, cell D12 displays which means the corresponding name from List A (in this case, “Aracely Rock”) does not exist within List B.
This example demonstrates how to determine if a particular value – in this case a name – in List A also exists within List B. To find the opposite – whether a name in List B also exists within List A – simply change the formula in cell D5 to: =IF(COUNTIF(A:A,B5),B5,0)
and press Enter. Then copy that formula down to the end of the lists.
How & Why it Works
Our formula makes use of two functions, IF
and COUNTIF
. The IF
function checks whether a condition is met, and returns one value if TRUE, and another value if FALSE. COUNTIF
counts the number of cells within a range that meet the given condition.
The Formula
=IF(COUNTIF(B:B,A5),A5,0)
COUNTIF
has two required arguments, or inputs, to work:
range
(where should Excel look, B:B in our example)criteria
(what should Excel find, A5 in our example)
COUNTIF
checks column B (using B:B checks the entire column) for the name in cell A5. If it finds the name (i.e. the criteria
you specified was met) it returns 1, otherwise it returns 0. Note: when COUNTIF
returns 1 or 0, Excel treats that as TRUE (1) or FALSE (0).
The IF
function has three required arguments, or inputs, to work:
logical_test
(any value or expression that can be evaluated to TRUE or FALSE)[value_if_true]
(what value should Excel return if iflogical_test
is TRUE)[value_if_false]
(what value should Excel return iflogical_test
is FALSE)
In our example COUNTIF
is the logical_test
that gives the IF
function either a 1 or 0, depending on whether it finds the name we specified from cell A5 within column B. If it finds the name (i.e. the logical_test
is TRUE), we specified A5 as the [value_if_true]
so Excel will display that name and move on. If it does not find the name (i.e. the logical_test
is FALSE), we specified 0 as the [value_if_false]
, so Excel will display 0 and move on.
You can quickly see a list of names missing from List B by filtering List C to show only “0.” The conditional formatting just makes it easier to spot the missing values.
Practice Yourself
The best way to learn is to practice yourself, so click the link below to download the Excel 2010 workbook used to show the methods described in this post. Please feel free to share!
19 responses to “Compare Two or More Lists in Excel with IF and COUNTIF”
Worked like a charm, thank you!
I used the formula as above but changed the true value, second last in formula to 1 in stead of a cell number. Counted all the ones and zeroes in the third column and it gave me the number of matches in both columns. Great!
Glad I could help, and nice work modifying the formula to better fit your needs!
Hi,
I have three lists and I need to find out which values are common to all three.
For example, I have three lists – A, B, C, each containing names of various cities around the world. I need to list out those (common) cities that present in all the three lists.
Would you tell me formula would be best suited for this scenario.
Thanks much.
I cant give you a formula, but i would start by merging the three lists into one, like described here: http://www.excel-aid.com/excel-consolidate-consolidating-data.html for example. Then i would use a “count column”, that will show a number absed on how often data is present. Then you just sort by number, and every row with the value “3” is what you want. There is probably a better way to do it, so maybe you want to wait for that. I hope i could help you, anyway.
=if( And (Countif(B:B,A1), Countif(C:C,A1)), TRUE, FALSE)
This will check to see if A1 appears in both list 2 and list 3. If it only appears in list 1 (and maybe 1 other), it will trigger FALSE. We do not need to check the other lists, since if it does not appear in list 1 (A:A), then it cannot appear in all 3 (only 2 at best).
Thank you!! Worked great.
Can you adapt the formula so that is shows what isn’t there? So the above formula will pull through the matching and then show a 0 but I would like it to show the cell content that doesn’t appear in the list. Any ideas?!
Flip the A5 with the zero. Think of it as inverting your question in the =IF statement. What you want instead is COUNTIF(“range of names”, “Cell#ofName you want to see”),””,”Cell#ofName you want to see”). The “” functions as a blank instead of a zero.
I’ve also used =IF(ISERROR(MATCH(“name of person”,”Range of array”,0)),”name of person,””)
=IF(ISERROR(MATCH(A218,$C$2:$C$255,0)),A218,””)
What I want/am working on now is either the follow up formula, or a way to nest this into one, that outputs the actual names in a new list in column D. Filtering works great, but it’d be nice to just get the values of everything so you can select it without catching all the garbage in between.
What’s the password for the example? It’s sheet protected.
Even though i have used your formula it displays only the formula not the result.
Can you say What wrong i did?
Select the cell in question, then Press
CTRL + `
(grave accent). It’s the key often located just below the “esc” key, and just to the left of the “1” key.If you want to know more about “Using If Function to Compare Dates of Two Cells”, check this link ……..
http://www.exceltip.com/tips/using-if-function-to-compare-dates-of-two-cells.html
Compute the grades based on following criteria (show the logic)
If percentage >= 80 and < 90 then grade = B
in Excel
Brilliant Explanation, thanks very much
awesome! thanks for sharing 🙂
I have in sig fig format. The sig figs match, but always return as a non-match because the values are rounded. Is there a way to return as a match?
Ooooo!!!!! what a wonderful formular buuuuuuu!!!!!!! it worked on my data, thank you very much God bless you abundantly…
[…] This post has become one of my most important resources every year. I’m terrified that one year I’ll pull up this link and the site will be dead, so I’ll be copy/pasting his steps below. Once again, visit his site (BigHungryGeek). He’s way smarter than I am! […]