Filtering Data



AutoFilter

If you use the Selection.AutoFilter Filter:=2 then it will reset just column 2, if you use Selection.AutoFilter then it will reset on all columns and will remove the AutoFilter completely.


Worksheets("Data").Select 
Worksheets("Data").AutoFilterMode = True
Range("A2").AutoFilter
Range("A2").AutoFilter Field:=3, Criteria1:="filter"

Show all Records

If ActiveSheet.AutoFilter.FilterMode Then 
   ActiveSheet.AutoFilter.ShowAllData
End If

Toggle on or off

If Not ActiveSheet.AutoFilterMode Then 
   ActiveSheet.Range("A1").AutoFilter
End If

Remove a filter if it exists

Worksheets("Data").AutoFilterMode = False 

ActiveWindow.AutoFilterDateGrouping = Not ActiveWindow.AutoFilterDateGrouping 


If ActiveSheet.AutoFilterMode Then 
   MsgBox "There is a Filter"
Else
   MsgBox "There is no Filter"
   Selection.AutoFilter
End If


Range("B2").Select 

The following line adds the autofilter to the currentregion of the active cell.

ActiveCell.AutoFilter 

ActiveCell.AutoFilter Criteria="String" 
ActiveCell.AutoFilter Field:=1, Criteria:=">10/07/2004", Operator:=xlAnd, Criteria2:="<16/07/2002"

Range("Database").Select 


Removing all existing filters

ActiveSheet.ShowAllData 

The above line causes run-time error if filtering is not applied - TEST THIS

On Error Resume Next 
ActiveSheet.ShowAllData


Advanced Filter

Copy To Range

Dim rgeCriteria As Range 
Dim rgeExtract As Range

Set rgeCriteria = Range("A2:A4")
Set rgeExtract = Range("C2")
Range("B2").CurrentRegion.AdvancedFilter Action:=xlFilterCopy, _
                                         CriteriaRange:=rgeCriteria, _
                                         CopyToRange:=rgeExtract

Getting a List of Unique Items
Here are four examples of counting unique values in a list. Each of these examples creates an array of the unique items, so they can be modified to to those arrays for a purpose other than just counting the unique items.


Sub cMethodAdvFilter() 
    CountUniqueByAdvFilter Selection.Address
End Sub

Sub CountUniqueByAdvFilter(mRange As String)
    Dim TheRange As String
    Application.ScreenUpdating = False
    
    TheRange = "'[" & ActiveWorkbook.Name & _
    "]" & ActiveSheet.Name & "'!" & mRange
    
    Workbooks.Add
    
    Range(TheRange).AdvancedFilter Action:=xlFilterCopy, CopyToRange _
:=Range("A1"), Unique:=True
    
    MsgBox Application.WorksheetFunction.CountA(Range("A:A"))
    
    ActiveWorkbook.Close False
    
    Application.ScreenUpdating = True
End Sub


© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext