looping with Auto Filter

Smithsat34

Board Regular
Joined
Jan 20, 2014
Messages
54
Hi board,

I recorded the following macro:

Sub Macro1()
'
' Macro1 Macro
'

'
ActiveSheet.Range("$A$1:$Q$2975").AutoFilter Field:=2, Criteria1:="2014"
Range("A1").Select
Range(Selection, ActiveCell.SpecialCells(xlLastCell)).Select
Application.CutCopyMode = False
Selection.Copy
Sheets.Add After:=Sheets(Sheets.Count)
ActiveSheet.Paste
Sheets("Bord Dec. 18").Select
Range("B1").Select
End Sub

What would be great would be if I could somehow loop through a list of values for criteria1. i.e. 2018, 2017, 2016, 2015, 2014.
If I could then define the name of each 'new' sheet with the criteria1 selection.

Any suggestions gratefully received

Regards
Smith
 

Excel Facts

Show numbers in thousands?
Use a custom number format of #,##0,K. Each comma after the final 0 will divide the displayed number by another thousand
Do you want a new sheet for every value in col B, or just some?
 
Upvote 0
If they are all in order like that, you could so something like:
Code:
For yr = 2014 to 2018
[COLOR=#333333]    ActiveSheet.Range("$A$1:$Q$2975").AutoFilter Field:=2, Criteria1:=yr
    ...
[/COLOR]
Or, you could store the values in an array, and iterate through it, i.e.
Code:
Dim yr as Variant
Dim i as Long
yr = Array("2014", "2015", "2016", "2017", "2018")
For i = LBound(yr) to UBound(yr)
[COLOR=#333333]    ActiveSheet.Range("$A$1:$Q$2975").AutoFilter Field:=2, Criteria1:=yr(i)
    ...[/COLOR]
 
Last edited:
Upvote 0
Other idea. Assuming you have a header in row 1.

Code:
Sub Looping_Auto_Filter()
    Dim sh As Worksheet, Ky As Variant, c As Range
    
    Set sh = ActiveSheet
    If sh.AutoFilterMode Then sh.AutoFilterMode = False
    With CreateObject("scripting.dictionary")
        For Each c In sh.Range("B2", sh.Range("B" & Rows.Count).End(xlUp))
            If c.Value <> "" Then .Item(c.Value) = Empty
        Next
        For Each Ky In .Keys
            sh.Range("A1").AutoFilter 2, Ky
            Sheets.Add after:=Sheets(Sheets.Count)
            sh.AutoFilter.Range.EntireRow.Copy Range("A1")
        Next
    End With
    sh.ShowAllData
End Sub
 
Upvote 0
Thanks All,
I went with Joe4's solution to get me going but when I get a chance I'll have a go with Dante's as it may solve another issue that I think is coming! Once again, thanks for looking
 
Upvote 0
Thanks All,
I went with Joe4's solution to get me going but when I get a chance I'll have a go with Dante's as it may solve another issue that I think is coming! Once again, thanks for looking

That is the idea, that the solution serves for this problem or perhaps for some other problem of some other person.
 
Upvote 0

Forum statistics

Threads
1,223,227
Messages
6,170,848
Members
452,361
Latest member
d3ad3y3

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