VBA Filter range by more than 1 criteria using cell reference

floggingmolly

Board Regular
Joined
Sep 14, 2019
Messages
167
Office Version
  1. 365
Platform
  1. Windows
I have a worksheet with data in A3 - I 1400. Column A contains Station #'s. I want the user to be able to enter multiple station #'s in Row 2 (B2, C2, D2) and filter the data by those stations. If I use an array in the VBA it filters by the station #'s, but I want it to reference cells B2, C2, D2, etc. Is anyone able to assist? Below is the code I have with station #'s as an array but this obviously isn't what I need. I need the Criteria to be a range I'm guessing to reference cells? I can't figure it out. Any help would be greatly appreciated.

Code:
Sub Filter()
Sheet1.Range("A3:I3").AutoFilter Field:=1, _
                                 Criteria1:=Array("11", "16"), _
                                 Operator:=xlFilterValues
End Sub
 

Excel Facts

What is =ROMAN(40) in Excel?
The Roman numeral for 40 is XL. Bill "MrExcel" Jelen's 40th book was called MrExcel XL.
Try:
VBA Code:
Sub Filter()
    Dim arr As Variant, lCol As Long
    lCol = Cells(2, Columns.Count).End(xlToLeft).Column - 1
    arr = Range("B2").Resize(, lCol).Value
    Sheet1.Range("A3").AutoFilter Field:=1, Criteria1:=arr, Operator:=xlFilterValues
End Sub
 
Upvote 0
Doesn't seem to work. It filters the entire sheet and nothing is visible. My goal is so they can enter up to 3 station numbers in B2, C2, and D2 and filter the data by up to 3 stations. I can get it to filter by 1 station using this code below. Not sure how to add in C2 and D2.

Code:
Sub Filter()
Sheet1.Range("A3:I3").AutoFilter Field:=1, Criteria1:=Range("B2").Value
End Sub

Try:
VBA Code:
Sub Filter()
    Dim arr As Variant, lCol As Long
    lCol = Cells(2, Columns.Count).End(xlToLeft).Column - 1
    arr = Range("B2").Resize(, lCol).Value
    Sheet1.Range("A3").AutoFilter Field:=1, Criteria1:=arr, Operator:=xlFilterValues
End Sub
 
Upvote 0
The code I suggested worked on some dummy data. It would be easier to help if you could use the XL2BB add-in (icon in the menu) to attach a screenshot (not a picture) of your sheet. Alternately, you could upload a copy of your file to a free site such as www.box.com or www.dropbox.com. Once you do that, mark it for 'Sharing' and you will be given a link to the file that you can post here. Explain in detail what you want to do referring to specific cells, rows, columns and sheets using a few examples from your data (de-sensitized if necessary).
 
Upvote 0
The code I suggested worked on some dummy data. It would be easier to help if you could use the XL2BB add-in (icon in the menu) to attach a screenshot (not a picture) of your sheet. Alternately, you could upload a copy of your file to a free site such as www.box.com or www.dropbox.com. Once you do that, mark it for 'Sharing' and you will be given a link to the file that you can post here. Explain in detail what you want to do referring to specific cells, rows, columns and sheets using a few examples from your data (de-sensitized if necessary).
I don't have dropbox and I tried the XL2BB add-in a few times and can't figure it out. Really all I want is in cells B2, C2, and D2 the user can enter a station number. I want the data to filter according what to what station #'s they enter. So if they put 11, 24, and 40 in cells B2, C2, and D2 I want the data to filter by those stations which are listed in column A. My code will work for one cell, B2, but not sure how to add more so it looks at B2, C2, and D2.
Code:
Sub Filter()
Sheet1.Range("A3:I3").AutoFilter Field:=1, Criteria1:=Range("B2").Value
End Sub
 
Upvote 0
How about
VBA Code:
Sub Filter()
Sheet1.Range("A3:I3").AutoFilter 1, Range("B2:D2").Value, xlFilterValues
End Sub
 
Upvote 0
How about
VBA Code:
Sub Filter()
Sheet1.Range("A3:I3").AutoFilter 1, Range("B2:D2").Value, xlFilterValues
End Sub
I tried and that filtered out everything so no rows were showing. I tried this and it worked with 2 criteria, but if I try to add the 3rd, it doesn't work. I just found where you can only use 2 with Operator:=xlOr so I guess that idea is out. haha

Code:
Sub Filter()
Sheet1.Range("A3:I3").AutoFilter Field:=1, Criteria1:=Range("B2").Value, _
Operator:=xlOr, Criteria2:=Range("C2").Value
End Sub
 
Upvote 0
You can only have more than 2 criteria by using an array.
Make sure that B2:D2 are text values & not numbers.
 
Upvote 0
You can only have more than 2 criteria by using an array.
Make sure that B2:D2 are text values & not numbers.
ahhhh, I changed them to Text and it looks like your code might actually work. I wasn't even thinking about the formatting. I think this might give me what I need. I appreciate the time you took to help me. This should get me started on this project so I am very thankful.
 
Upvote 0
Glad we could help & thanks for the feedback.
 
Upvote 0

Forum statistics

Threads
1,225,748
Messages
6,186,795
Members
453,371
Latest member
HMX180

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top