Make VBA String Comparisons Case In-sensitive [Quick Tip]

Share

Facebook
Twitter
LinkedIn

Today, while answering a reader’s email, I wrote this VBA code,

If Target.Value = "yes" Then
'do something
End If

But I realized that my code would run only the Target cell has “yes” in it. It wont run if the target cell has “YES”, or “Yes” or “YeS”.

This is because by default, all VBA comparisons are binary. That means, “yes” ≠ “Yes”.

One quick work-around for this problem is to use UCASE to convert target.value to Uppercase and then compare, like this,

If UCASE(Target.Value) = "YES" Then
'do something
End If

But this seemed painful, especially, if I had to do similar comparison at multiple places in my code, I had to use UCASE() everywhere.

If only there is an option to tell VBA how to compare?!?

Well, there is an option.

Use Option Compare Text

If you write Option Compare Text at the top of your module, all the VBA comparisons with in that module will use Text comparison instead of Binary comparison. Thus, “yes” will be equal to “YES”.

Do you use Option Compare?

There are 3 settings for Option Compare.

  1. Option Compare Binary: This is the default setting. Compares everything at binary level.
  2. Option Compare Text: Used for situations like this.
  3. Option Compare Database: Can be used only with MS Access VBA. Uses Database Table settings to determine how to compare.

This is the first time I have used Option Compare Text. But it seems like an elegant way to tell Excel VBA how to compare. I will be using it more often.

What about you? Do you use Option Compare? What are your favorite tips & tricks? Please share with us using comments.

More on Excel VBA

VBA (or Macros) is how you can tell Excel to automate parts of your work. It is a powerful programming language built right in to Excel (and other MS Office applications) to help you do more. If you are new to VBA, why don’t you go thru our Free crash course?

  1. Introduction to VBA & Excel Macros
  2. Understanding Variables, Conditions & Loops in VBA
  3. Using Cells, Ranges & Other Objects in your Macros
  4. Putting it all together – Your First VBA Application using Excel
  5. My Top 10 Tips for Mastering VBA & Excel Macros

Also, go thru our VBA (Macros) article collection for more tips, tutorials & ideas.

Facebook
Twitter
LinkedIn

Share this tip with your colleagues

Excel and Power BI tips - Chandoo.org Newsletter

Get FREE Excel + Power BI Tips

Simple, fun and useful emails, once per week.

Learn & be awesome.

Welcome to Chandoo.org

Thank you so much for visiting. My aim is to make you awesome in Excel & Power BI. I do this by sharing videos, tips, examples and downloads on this website. There are more than 1,000 pages with all things Excel, Power BI, Dashboards & VBA here. Go ahead and spend few minutes to be AWESOME.

Read my storyFREE Excel tips book

Overall I learned a lot and I thought you did a great job of explaining how to do things. This will definitely elevate my reporting in the future.
Rebekah S
Reporting Analyst
Excel formula list - 100+ examples and howto guide for you

From simple to complex, there is a formula for every occasion. Check out the list now.

Calendars, invoices, trackers and much more. All free, fun and fantastic.

Advanced Pivot Table tricks

Power Query, Data model, DAX, Filters, Slicers, Conditional formats and beautiful charts. It's all here.

Still on fence about Power BI? In this getting started guide, learn what is Power BI, how to get it and how to create your first report from scratch.

One Response to “How to compare two Excel sheets using VLOOKUP? [FREE Template]”

  1. Danny says:

    Maybe I missed it, but this method doesn't include data from James that isn't contained in Sara's data.

    I added a new sheet, and named the ranges for Sara and James.

    Maybe something like:
    B2: =SORT(UNIQUE(VSTACK(SaraCust, JamesCust)))
    C2: =XLOOKUP(B2#,SaraCust,SaraPaid,"Missing")
    D2: =XLOOKUP(B2#,JamesCust, JamesPaid,"Missing")
    E2: =IF(ISERROR(C2#+D2#),"Missing",IF(C2#=D2#,"Yes","No"))

    Then we can still do similar conditional formatting. But this will pull in data missing from Sara's sheet as well.

Leave a Reply