Amnesia of global object variables

nigelandrewfoster

Well-known Member
Joined
May 27, 2009
Messages
747
Is there any way of declaring and setting the value of a global object variable so it keeps its value when the procedure ends? The system I'm developing runs separate macros according to the user's clicking on clip art, returning the user to Excel level after each one has run. As it stands, the moment the macro finishes, all the global object variables I have declared are cleared, so the next click generates an "Object variable or With block not set" error. I have gotten around this by writing a macro which simply contains SET statements for them all, and each macro then starts with a CALL command to this macro. Is that the correct way to go, or is there a more direct way, please? As ever, I appreciate your time!
Nigel
 

Excel Facts

How to fill five years of quarters?
Type 1Q-2023 in a cell. Grab the fill handle and drag down or right. After 4Q-2023, Excel will jump to 1Q-2024. Dash can be any character.
Nigel

Where are you declaring the varible(s) and how do you initially set them?

Is there anything in the code being executed that could cause the reference to be lost?
 
Upvote 0
Hi,
Public statement in declarations above regular modules. Originally followed advice to put SET statements in WorkbooksOpen procedure in ThisWorkbook module. Didn't work. So just put a CALL there instead to a Sub called Initialise_Globals which just contains my set statements. That way, when the control is passed back to Excel and the definitions are lost, I can just put a CALL statement at the beginning of each macro I'm running.
 
Last edited:
Upvote 0
So module 1 looks like this:
Code:
Option Explicit
Public Jimmy As Range, Pog As Range

Sub James()
    Call Initialise_Globals
    Jimmy = "Hi, I'm Jimmy!"
    Pog = "I'm not!"
End Sub

Thisworkbook looks like this:
Code:
Option Explicit

Private Sub WorkbookOpen()
    Call Initialise_Globals
End Sub

and module 2 looks like this:
Code:
Option Explicit

Sub Initialise_Globals()
    Set Jimmy = Workbooks("Nigel Foster").Worksheets("Nigel").Range("d12")
    Set Pog = Workbooks("Nigel Foster").Worksheets("Nigel").Range("d16")
End Sub
 
Upvote 0
Is it definitely WorkbookOpen and not Workbook_Open?

That's the only problem I can see.
 
Upvote 0
Have changed it to workbook_open. Thanks. My front end consists of a table of order information. The user selects the ORDER worksheet tab which automatically runs a macro to display a listbox with customer names in. The user selects a name and the front end table displays the relevant customer's order info (which is taken from a hidden, compact master table). So far, so good. The user makes amendments and then clicks "SAVE" wordart to run another macro, updating the master table. There will be numerous other buttons added. Do I have to initialise globals every time control passes back to the user and the user runs a new macro? (i.e. Does the values of global object variables get lost each time a procedure ends? Because they appear to.) Thanks.
 
Upvote 0
No, unless your code does something that resets the project. I note you mention listboxes - are you using an activex listbox on a sheet? Adding one of those will reset the project.
 
Upvote 0
Maybe it's when I'm debugging and I have to RESET in order to run the next macro? I've gotten round it by placing CALL initialise_globals command at start of every macro that a user could initiate. I'll do some more experimenting. No, not an active x one. I call it into existence via a .show command.
Thanks
Nigel
 
Last edited:
Upvote 0
Yes - if you reset, all your globals will get reset too.
 
Upvote 0
Nigel

Are you just putting the call to create initialise the variables at the start of each module for debugging?
 
Upvote 0

Forum statistics

Threads
1,224,502
Messages
6,179,126
Members
452,890
Latest member
Nikhil Ramesh

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