Running one macro in several sheets by a code

Reza1001

New Member
Joined
Sep 9, 2024
Messages
6
Office Version
  1. 2021
  2. 2019
Platform
  1. Windows
Hi dears

i have a file including 30 sheets . in some sheets i have one rectangle ( named "100" ) which must be hidden/unhidden and a rounded rectangle ( named "200" ) which must be colorized . i have written two macros for this matter . one of them is this :

Sub ProtBUDCOK()
'
' ProtBUDCOK Macro
'
'
ActiveSheet.Shapes.Range(Array("Rectangle: Rounded Corners 200")).Select
With Selection.ShapeRange.Fill
.Visible = msoTrue
.ForeColor.RGB = RGB(187, 170, 43)
.Transparency = 0
.Solid

End With

Range("s1").Select
ActiveSheet.Shapes.Range(Array("Rectangle 100")).Select
ActiveSheet.Shapes.Range(Array("Rectangle 100")).Visible = msoFalse
End Sub


i want to run this macro and other one by bottoms in sheet1 for sheet2,sheet5,sheet6 and sheet9 ( with codenames ) . below code doesn't work maybe because of ActiveSheet part of above macro or wrong addressing in sheet names . please help me.

Sub RunOnAllSheets()

Application.ScreenUpdating = False

For Each Worksheet In ThisWorkbook.Worksheets
Debug.Print wrkSht.Name
Sheets(Array("Sheet2", "Sheet5", "Sheet6", "Sheet9")).Select

Call ProtBUDBOK
Next
Application.ScreenUpdating = True

End Sub
 

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
I have done minimum changes in the code .Try on a copy of file.
VBA Code:
Sub RunOnAllSheets()
Dim Sh
Application.ScreenUpdating = False

For Each Sh In Array("Sheet2", "Sheet5", "Sheet6", "Sheet9")
Debug.Print Sh
Sheets(Sh).Activate
ActiveSheet.Shapes.Range(Array("Rectangle: Rounded Corners 200")).Select
With Selection.ShapeRange.Fill
.Visible = msoTrue
.ForeColor.RGB = RGB(187, 170, 43)
.Transparency = 0
.Solid
End With

Range("s1").Select
ActiveSheet.Shapes.Range(Array("Rectangle 100")).Select
ActiveSheet.Shapes.Range(Array("Rectangle 100")).Visible = msoFalse
Next Sh
Application.ScreenUpdating = True

End Sub
 
Upvote 0
it works . thank u 🙏
another question . how can i Refer to sheets by CodeName instead sheet names in this macro? means for this part : For Each Sh In Array("Sheet2", "Sheet5", "Sheet6", "Sheet9")
 
Upvote 0
it works . thank u 🙏
another question . how can i Refer to sheets by CodeName instead sheet names in this macro? means for this part : For Each Sh In Array("Sheet2", "Sheet5", "Sheet6", "Sheet9")
by 'CodeName' do you mean the programable sheet number, so the code doesnt break when the sheet is renamed?

You can do this by just referring to the number of the sheet itself. Typically this is 1 for Sheet1, 2 for Sheet2 and so on.

It would look like this.

VBA Code:
Sheets(1).Activate
 
Upvote 0
Try...

VBA Code:
Sub ProtBUDCOK()

    Dim i As Integer, myArr As Variant, ws As Worksheet
    myArr = Array("Sheet2", "Sheet5", "Sheet6", "Sheet9")


    For Each ws In ActiveWorkbook.Worksheets
        
        For i = LBound(myArr) To UBound(myArr)
            
            If ws.CodeName = myArr(i) Then
                
                
                    With ws.Shapes("200").Fill
                        .Visible = msoTrue
                        .ForeColor.RGB = RGB(187, 170, 43)
                        .Transparency = 0
                        .Solid
                    End With
              

                ws.Shapes("100").Visible = msoTrue

            End If
        
        Next i
    
    Next ws

End Sub

Edit: done away with an unnecessary "With" statement
 
Last edited:
Upvote 0
You can use the actual sheet names.
my sheet names are changing monthly . that's why i am trying to use codenames which are permanent . even by adding or removing sheets . Array("Sheet2", "Sheet5", "Sheet6", "Sheet9") is reffering to sheet names not codenames of sheets . for example codnames of my sheets are these : "Sheet2"=sheet1 "Sheet5"=sheet3 "Sheet6"=sheet2 "Sheet9"=sheet5
 
Upvote 0
by 'CodeName' do you mean the programable sheet number, so the code doesnt break when the sheet is renamed?

You can do this by just referring to the number of the sheet itself. Typically this is 1 for Sheet1, 2 for Sheet2 and so on.

It would look like this.

VBA Code:
Sheets(1).Activate
thanks . you are referring to index names. Codenames are better without the problems of renaming and reordering sheets
 
Upvote 0
how can i Refer to sheets by CodeName instead sheet names in this macro? means for this part : For Each Sh In Array("Sheet2", "Sheet5", "Sheet6", "Sheet9")

Hi
untested but try this update to your code & see if does what you want

VBA Code:
Sub ProtBUDCOK()
    
    Dim sh          As Variant
    
    For Each sh In Array(Sheet2, Sheet5, Sheet6, Sheet9)
        
        With sh.Shapes("Rectangle: Rounded Corners 200").Fill
            
            .Visible = msoTrue
            .ForeColor.RGB = RGB(187, 170, 43)
            .Transparency = 0
            .Solid
            
        End With
        
        sh.Shapes("Rectangle 100").Visible = msoFalse
        
    Next sh
    
End Sub

Dave
 
Upvote 0

Forum statistics

Threads
1,225,738
Messages
6,186,728
Members
453,368
Latest member
positivemind

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