Hey All!
I was wondering if someone could help with a problem I'm having trying to implement programatically added buttons that launch a macro.
I'm using the accepted solution from here - excel - How to add a button programmatically in VBA next to some sheet cell data? - Stack Overflow
The buttons are added successfully but don't call the macros when pushed. Instead they give the error
%workbookname% is just the placeholder for the name of the actual workbook the code is in.
I've tried making the function btnS public in my version, and tried moving the functions from 'This workbook' to 'Sheet 1' but nothing's made a difference, I sill get the error listed above.
Could anyone point out where I'm going wrong? I'd really appreciate it!data:image/s3,"s3://crabby-images/a0dd6/a0dd67a17ec8b6e6bcb45d7047f3d9bfe87084bb" alt="Smile :) :)"
Thanks in advance!
I was wondering if someone could help with a problem I'm having trying to implement programatically added buttons that launch a macro.
I'm using the accepted solution from here - excel - How to add a button programmatically in VBA next to some sheet cell data? - Stack Overflow
Code:
[COLOR=#101094][FONT=Consolas]Sub[/FONT][/COLOR][COLOR=#303336][FONT=Consolas] a[/FONT][/COLOR][COLOR=#303336][FONT=Consolas]()
[/FONT][/COLOR]<code style="margin: **** padding: **** border: **** font-family: Consolas, Menlo, Monaco, "Lucida Console", "Liberation Mono", "DejaVu Sans Mono", "Bitstream Vera Sans Mono", "Courier New", monospace, sans-serif; white-space: inherit;">[COLOR=#101094] Dim[/COLOR][COLOR=#303336] btn [/COLOR][COLOR=#101094]As[/COLOR][COLOR=#303336] Button
Application[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]ScreenUpdating [/COLOR][COLOR=#303336]=[/COLOR][COLOR=#7D2727]False[/COLOR][COLOR=#303336]
ActiveSheet[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Buttons[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Delete
[/COLOR][COLOR=#101094]Dim[/COLOR][COLOR=#303336] t [/COLOR][COLOR=#101094]As[/COLOR][COLOR=#303336] Range
[/COLOR][COLOR=#101094]For[/COLOR][COLOR=#303336] i [/COLOR][COLOR=#303336]=[/COLOR][COLOR=#7D2727]2[/COLOR][COLOR=#101094]To[/COLOR][COLOR=#7D2727]6[/COLOR][COLOR=#101094]Step[/COLOR][COLOR=#7D2727]2[/COLOR][COLOR=#303336]
[/COLOR][COLOR=#101094]Set[/COLOR][COLOR=#303336] t [/COLOR][COLOR=#303336]=[/COLOR][COLOR=#303336] ActiveSheet[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Range[/COLOR][COLOR=#303336]([/COLOR][COLOR=#303336]Cells[/COLOR][COLOR=#303336]([/COLOR][COLOR=#303336]i[/COLOR][COLOR=#303336],[/COLOR][COLOR=#7D2727]3[/COLOR][COLOR=#303336]),[/COLOR][COLOR=#303336] Cells[/COLOR][COLOR=#303336]([/COLOR][COLOR=#303336]i[/COLOR][COLOR=#303336],[/COLOR][COLOR=#7D2727]3[/COLOR][COLOR=#303336]))[/COLOR][COLOR=#303336]
[/COLOR][COLOR=#101094]Set[/COLOR][COLOR=#303336] btn [/COLOR][COLOR=#303336]=[/COLOR][COLOR=#303336] ActiveSheet[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Buttons[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Add[/COLOR][COLOR=#303336]([/COLOR][COLOR=#303336]t[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Left[/COLOR][COLOR=#303336],[/COLOR][COLOR=#303336] t[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Top[/COLOR][COLOR=#303336],[/COLOR][COLOR=#303336] t[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Width[/COLOR][COLOR=#303336],[/COLOR][COLOR=#303336] t[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Height[/COLOR][COLOR=#303336])[/COLOR][COLOR=#303336]
[/COLOR][COLOR=#101094]With[/COLOR][COLOR=#303336] btn
[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]OnAction [/COLOR][COLOR=#303336]=[/COLOR][COLOR=#7D2727]"btnS"[/COLOR][COLOR=#303336]
[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Caption [/COLOR][COLOR=#303336]=[/COLOR][COLOR=#7D2727]"Btn "[/COLOR][COLOR=#303336]&[/COLOR][COLOR=#303336] i
[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Name [/COLOR][COLOR=#303336]=[/COLOR][COLOR=#7D2727]"Btn"[/COLOR][COLOR=#303336]&[/COLOR][COLOR=#303336] i
[/COLOR][COLOR=#101094]End[/COLOR][COLOR=#101094]With[/COLOR][COLOR=#303336]
[/COLOR][COLOR=#101094]Next[/COLOR][COLOR=#303336] i
Application[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]ScreenUpdating [/COLOR][COLOR=#303336]=[/COLOR][COLOR=#7D2727]True[/COLOR][COLOR=#303336]
[/COLOR][COLOR=#101094]End[/COLOR][COLOR=#101094]Sub[/COLOR][COLOR=#303336]
[/COLOR][COLOR=#101094]Sub[/COLOR][COLOR=#303336] btnS[/COLOR][COLOR=#303336]()[/COLOR][COLOR=#303336]
MsgBox Application[/COLOR][COLOR=#303336].[/COLOR][COLOR=#303336]Caller
[/COLOR]</code>[COLOR=#101094][FONT=Consolas]End [/FONT][/COLOR][COLOR=#101094][FONT=Consolas]Sub
[/FONT][/COLOR]
The buttons are added successfully but don't call the macros when pushed. Instead they give the error
Code:
Cannot run the macro "%workbookname%'!btnS'. The macro may not be available in this workbook or all macros may be disabled.
I've tried making the function btnS public in my version, and tried moving the functions from 'This workbook' to 'Sheet 1' but nothing's made a difference, I sill get the error listed above.
Could anyone point out where I'm going wrong? I'd really appreciate it!
data:image/s3,"s3://crabby-images/a0dd6/a0dd67a17ec8b6e6bcb45d7047f3d9bfe87084bb" alt="Smile :) :)"
Thanks in advance!
Last edited: