How to Filter a Table based on Cell Values with Excel VBA (6 Methods)

Dataset Overview

We’ve included a sample dataset in the figure below, from which we’ll sift through values according to specific cell criteria. Using Excel VBA, we’ll sort out results based on text conditions, multiple criteria (both AND and OR), and cell values.

Sample Data


Method 1 – Filtering a Table Based on a Text Condition with Excel VBA

To filter a table based on a Text Condition, follow these steps:

  • Initiate a VBA Macro by pressing Alt + F11.
  • Click on the Insert tab.
  • Select Module.

Handy Approaches to Filter Table Based on Cell Value with Excel VBA

  • Paste the following VBA codes into the Module:
Sub Text_condition()
Worksheets("Sheet1").Range("B4").AutoFilter Field:=2, Criteria1:="Beef"
End Sub

In this code:

  • The Field:=2 indicates the second column.
  • The first criterion, “Criteria1:=Beef,” filters for the text Beef.

Handy Approaches to Filter Table Based on Cell Value with Excel VBA

  • Save the program and press F5 to execute it.

Handy Approaches to Filter Table Based on Cell Value with Excel VBA

Read More: Filter Multiple Criteria in Excel with VBA (Both AND and OR Types)


Method 2 – Filtering a Table Based on Cell Value with Multiple Criteria

With Excel VBA, you can apply filters for multiple AND or OR criteria. Here’s how:

2.1 Based on OR Criteria

  • Select a new Module and paste the following VBA code:
Sub Multiple_Criteria_OR()
Worksheets("Sheet2").Range("B4").AutoFilter Field:=2, Criteria1:="Beef", Operator:=xlOr, Criteria2:="Chicken"
End Sub

Handy Approaches to Filter Table Based on Cell Value with Excel VBA

  • Save the program and press F5 to run it.

Handy Approaches to Filter Table Based on Cell Value with Excel VBA

2.2 Based on AND Criteria

  • In a new Module, paste the following VBA code:
Sub Multiple_Criteria_AND()
Worksheets("Sheet2").Range("B4").AutoFilter Field:=3, Criteria1:=">500", Operator:=xlAnd, Criteria2:="<2000"
End Sub

Here,

  • The First Criterion is a Sales value greater than 500.
  • Second Criterion is the Sales value of less than 2000.

Handy Approaches to Filter Table Based on Cell Value with Excel VBA

  • Save the program and run it by pressing F5.

Handy Approaches to Filter Table Based on Cell Value with Excel VBA

Read More: How to Filter Based on Cell Value Using Excel VBA


Method 3 – Filtering a Table Based on Multiple Criteria with Different Columns

In this method, we’ll apply multiple criteria in different columns:

  • Select a new Module from the Insert tab.
  • Copy and paste the following VBA code:
Sub Multiple_Criteria_With_Different_Columns()
With Worksheets("Sheet3").Range("B4")
.AutoFilter Field:=2, Criteria1:="Chicken"
.AutoFilter Field:=3, Criteria1:=">1000"
End With
End Sub

Handy Approaches to Filter Table Based on Cell Value with Excel VBA

  • Save the program and run it by pressing F5.

Handy Approaches to Filter Table Based on Cell Value with Excel VBA

Read More: Excel VBA: How to Filter with Multiple Criteria in Array


Method 4 – Applying the AutoFilter in the VBA Code to Filter Top 5 Records in a Table

To extract the top 5 values based on cell values:

  • Select a new Module from the Insert tab.
  • Copy and paste the following VBA code:
Sub Top_5_Records()
ActiveSheet.Range("B4").AutoFilter Field:=3, Criteria1:="5", Operator:=xlTop10Items
End Sub

Handy Approaches to Filter Table Based on Cell Value with Excel VBA

  • Save the program and run it by pressing F5.

Handy Approaches to Filter Table Based on Cell Value with Excel VBA

Read More: How to Remove Filter in Excel VBA


Method 5 – Using AdvancedFilter in the VBA Code to Filter Table Based on a Cell Value

You can dynamically enter values and filter results with Excel VBA:

  • Select a new Module from the Insert tab.
  • Paste the following VBA code:
Private Sub Worksheet_Change(ByVal Target As Range)
   If Target.Address = Range("F5").Address Then
       Range("B4:D11").CurrentRegion.AdvancedFilter Action:=xlFilterInPlace, CriteriaRange:=Range("F4:F5")
   End If 
End Sub
Sub BasedOnCellValue()
End Sub

Sample Data

  • Save the program and run it by pressing F5.
  • If you enter a value in cell F5 (Chicken), then all the values with the Chicken will be filtered.

Sample Data

Read More: Excel VBA to Filter in Same Column by Multiple Criteria


Method 6 – Applying Wildcard Characters to Filter a Table Based on a Cell Value

Wildcard characters (*) can be used to filter values in a cell that include a certain part. When we type Chicken in between wildcard characters, for example, it will extract all values containing Chicken.

  • Select a new Module from the Insert tab.
  • Copy and paste the following VBA code:
Sub Using_Wildcard_Characters()
Worksheets("Sheet6").Range("B4").AutoFilter Field:=2, Criteria1:="*Chicken*"
End Sub

Sample Data

  • Run the program after saving it.

Sample Data


Download Practice Workbook

You can download the practice workbook from here:


Related Articles

Get FREE Advanced Excel Exercises with Solutions!
Bhubon Costa
Bhubon Costa

Bhubon Costa, B.Sc. in Naval Architecture & Marine Engineering from Bangladesh University of Engineering & Technology, has worked with the ExcelDemy since 2021. Currently, he has been working as a reviewer. Notably, he has written over 90 articles and led several VBA content development teams. He has a great passion for the fields of data analytics and data science. His areas of expertise include Excel VBA, Power Query, Pivot Table, Power BI, MySQL, PostgreSQL, machine learning, and Python... Read Full Bio

2 Comments
  1. This page is all about filtering a table and yet no where do you actually refer to the table name or columns.

    Surely the whole benefit of using a table is you do not need to have hard-coded column/row references, e.g
    Range(“B4:D11”).CurrentRegion.AdvancedFilter…

    You can just use the table name:
    [tblMyTable].CurrentRegion.AdvancedFilter…

    Or:
    ActiveSheet.ListObjects(“tblMyTable”).databodyrange.AdvancedFilter…

    Then if anything changes in your table (ie new data rows are added) your code still works.

Leave a reply

Advanced Excel Exercises with Solutions PDF

 

 

ExcelDemy
Logo