Macro with variable tab names

Will85

Active Member
Joined
Apr 26, 2012
Messages
254
Office Version
  1. 365
Platform
  1. Windows
I have a a number of workbooks that each have 19 tabs. I have a macro that goes through each tab and hides some blank rows.

My current macro, as an example for one tab is as follows:

Sheets("1000").Select
ActiveSheet.Unprotect
ActiveSheet.Range("$A$1:$A$700").AutoFilter Field:=1, Criteria1:="1"
ActiveSheet.Protect

The sheet name "1000" is only applicable in one workbook, in another workbook the number scheme may change to "6001" as an example.

I would rather have my macro refer to a key to lookup the tab name, than actually hardcode the tab names in the macro.

For example, I have a tab called "Departments", and cells A1:A19 contain the department code that also corresponds to the tab names in each of the workbooks. I would prefer the macro pull the tab names from here, so that when I copy this workbook out I can change the "Departments" tab instead of the macro.

Thank you in advance for your help.
 

Excel Facts

Copy a format multiple times
Select a formatted range. Double-click the Format Painter (left side of Home tab). You can paste formatting multiple times. Esc to stop
How about
Code:
Sub hiderws()
   Dim ary As Variant
   Dim sht As Variant
   
   ary = Sheets("Departments").Range("A1:A19").Value
   For Each sht In ary
      With Sheets(CStr(sht))
         .Unprotect
         .Range("A1:A700").AutoFilter 1, "1"
         .Protect
      End With
   Next sht
End Sub
 
Upvote 0
Do all cells in A1:A19 contain valid sheet names?
 
Upvote 0
Im realizing that it worked, but its throwing that error.

Run-time error 9

Subscript out of range

With Sheets(CStr(sht)) is the highlighted code
 
Upvote 0
I realized what was happening, while testing it, I created a blank workbook, with one valid tab, and only put one value in cell A1 on the "Departments tab"

I think I will make the A1:A19 relative just in case in the future a user adds or deletes rows, its conceivable we could add an additional department. Thank you for your assistance.
 
Upvote 0
You can make the list dynamic like
Code:
Sub hiderws()
   Dim ary As Variant
   Dim sht As Variant
   
   With Sheets("Departments")
      ary = .Range("A1", .Range("A" & Rows.Count).End(xlUp)).Value
   End With
   For Each sht In ary
      With Sheets(CStr(sht))
         .Unprotect
         .Range("A1:A700").AutoFilter 1, "1"
         .Protect
      End With
   Next sht
End Sub
 
Upvote 0
At the end of the macro, after going through all sheets within the variable range. I want it to end by selecting the "Instructions" sheet (which is where I have the button that runs the macro)

I am struggling with this as I keep getting exceptions when I try to add Sheets("Instructions").Select
 
Upvote 0
That should work as long as you add it between these 2 lines
Code:
   Next sht
End Sub
 
Upvote 0
At the end of the macro, after going through all sheets within the variable range. I want it to end by selecting the "Instructions" sheet (which is where I have the button that runs the macro)

I am struggling with this as I keep getting exceptions when I try to add Sheets("Instructions").Select
 
Upvote 0

Forum statistics

Threads
1,225,750
Messages
6,186,805
Members
453,373
Latest member
Ereha

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