ExcelBanter

ExcelBanter (https://www.excelbanter.com/)
-   Excel Programming (https://www.excelbanter.com/excel-programming/)
-   -   Passing a variable from a macro in a separate workbook to the call (https://www.excelbanter.com/excel-programming/435774-passing-variable-macro-separate-workbook-call.html)

Spike

Passing a variable from a macro in a separate workbook to the call
 
I have a macro in book A that opens a workbook(book B) and runs a macro in
that workbook. I would like to return a variable set in the macro in book B
to the calling macro in Book A. Is this possible.

I know i could use a workaround by the macro in book B settiing a cell value
in book A with the required value
--
with kind regards

Spike

Paul

Passing a variable from a macro in a separate workbook to the call
 
yourMacro = "myMacro" ' the name of the macro you wish to run in the
new/second workbook

' Open your new/second workbook

yourNewBook = "myFile.xls" ' the name of the new/second workbook that you
have opened (presumably programmatically)

application.run ("'"+yourNewBook+"'!"&yourMacro)



"Spike" wrote:

I have a macro in book A that opens a workbook(book B) and runs a macro in
that workbook. I would like to return a variable set in the macro in book B
to the calling macro in Book A. Is this possible.

I know i could use a workaround by the macro in book B settiing a cell value
in book A with the required value
--
with kind regards

Spike


Dave Peterson

Passing a variable from a macro in a separate workbook to the call
 
If the macro in workbookB is a function, you could do it pretty easily:

This was saved from a post for a similar question. You'll have to change the
workbook name from personal.xls to the real name.

Dim pWkbk as workbook
set pwkbk = workbooks("Personal.xls")
application.run "'" & pwkb.name & "'!macronamehere", "parm1", "parm2"

or if you're returning a value from a function:

dim res as string 'or variant or long or ...
res = application.run("'" & pwkb.name & "'!macronamehere", "parm1", "parm2")

You could also create a reference to this personal.xls workbook and call it just
like it was built into excel.

Tools|references
(but give the personal.xls's project a nice unique name (not VBAProject).

ps.

If you're using a function living in personal.xls inside a cell:
=personal.xls!functionnamehere(a1,b1,c1)

or save the file as an addin (*.xla) and use it in the cell like it's built into
excel:
=functionnamehere(a1,b1,c1)

Spike wrote:

I have a macro in book A that opens a workbook(book B) and runs a macro in
that workbook. I would like to return a variable set in the macro in book B
to the calling macro in Book A. Is this possible.

I know i could use a workaround by the macro in book B settiing a cell value
in book A with the required value
--
with kind regards

Spike


--

Dave Peterson

Spike

Passing a variable from a macro in a separate workbook to the
 
Thank you that is very helpful

Many thanks
--
with kind regards

Spike


"Dave Peterson" wrote:

If the macro in workbookB is a function, you could do it pretty easily:

This was saved from a post for a similar question. You'll have to change the
workbook name from personal.xls to the real name.

Dim pWkbk as workbook
set pwkbk = workbooks("Personal.xls")
application.run "'" & pwkb.name & "'!macronamehere", "parm1", "parm2"

or if you're returning a value from a function:

dim res as string 'or variant or long or ...
res = application.run("'" & pwkb.name & "'!macronamehere", "parm1", "parm2")

You could also create a reference to this personal.xls workbook and call it just
like it was built into excel.

Tools|references
(but give the personal.xls's project a nice unique name (not VBAProject).

ps.

If you're using a function living in personal.xls inside a cell:
=personal.xls!functionnamehere(a1,b1,c1)

or save the file as an addin (*.xla) and use it in the cell like it's built into
excel:
=functionnamehere(a1,b1,c1)

Spike wrote:

I have a macro in book A that opens a workbook(book B) and runs a macro in
that workbook. I would like to return a variable set in the macro in book B
to the calling macro in Book A. Is this possible.

I know i could use a workaround by the macro in book B settiing a cell value
in book A with the required value
--
with kind regards

Spike


--

Dave Peterson
.



All times are GMT +1. The time now is 08:42 AM.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
ExcelBanter.com