Call a Macro from a User Form where the macro name is build

Anton_C

New Member
Joined
Jan 3, 2017
Messages
6
Hi MrExcel,

I created a generic userform which can work with multiple worksheets.


I have a macro in a module that will execute some code to export the sheet to another workbook. (i.e. macro name = Export_BOM_CostSummary() , or Export_BOM_PcsPc() etc.)


The sheet that I want to export has a portion of the macro name. (i.e. sheet name = BOM_CostSummary, or BOM_PcsPc etc.)


From my user form, when I click the Export command button the following should happen: (as I understand it)


Private Sub cmdExport_Click()
'*****************************<wbr>******************************<wbr>******************
'Load Active Workbook Sheet Name
'*****************************<wbr>******************************<wbr>******************


Dim AWS As String 'Active Workbook Sheet Name (AWS)

ActiveSheet.Select
AWS = ActiveSheet.Name ' BOM_CostSummary or BOM_PcsPc


'*****************************<wbr>******************************<wbr>******************
'Create Macro Name to be used
'*****************************<wbr>******************************<wbr>******************


Dim expMacro As String 'Export Macro


expMacro = "Export_" + AWS ' This creates the macro name to be called, (i.e. Export_BOM_CostSummary or Export_BOM_PcsPc)


'*****************************<wbr>******************************<wbr>******************


The expMacro returns the string value as: Export_BOM_CostSummary or Export_BOM_PcsPc



But I do not know what to do further to call the macro with the same name.




 

Excel Facts

Excel Wisdom
Using a mouse in Excel is the work equivalent of wearing a lanyard when you first get to college
to run a macro , just call it:

Rich (BB code):
Private Sub cmdExport_Click()
 Export_BOM_CostSummary
end sub

if you want dynamic, use params , but 1 macro
Export_BOM_CostSummary 1
or
Export_BOM_CostSummary 6



sub Export_BOM_CostSummary(byval pvParam)
select case pvParam
case 1
msgbox "1"
case 6
msgbox "6"
end select
end sub

 
Last edited:
Upvote 0
Hi Ranman,

This code is on a command button from a userform:

Private Sub cmdExport_Click()

Dim AWS As String 'Active Workbook Sheet Name (AWS)
Dim expMacro As String 'Export Macro

ActiveSheet.Select

AWS = ActiveSheet.Name ' BOM_CostSummary
expMacro = "Export_" + AWS ' This creates the macro name to be called, (i.e. Export_BOM_CostSummary)


I need the command to CALL or RUN the string (expMacro). This is a Macro that is found in a module:
Module name is: M10_Export_SchList
Macro name is: Sub BOM_CostSummary()

This is where I am stuck.
 
Upvote 0
If the sheet name & the sub name are the same, then simply use
Code:
Call AWS
 
Upvote 0
The names are not exactly the same, I am concatenating to get the same name;
AWS = ActiveSheet.Name ' BOM_CostSummary
expMacro = "Export_" + AWS ' This creates the macro name to be called, (i.e. Export_BOM_CostSummary)
 
Upvote 0
In post#3 you said
Macro name is: Sub BOM_CostSummary()
If that is the case then you do not need to add the prefix "Export_"
 
Upvote 0

Forum statistics

Threads
1,225,759
Messages
6,186,863
Members
453,380
Latest member
ShaeJ73

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