VBA to run the first time each month a spreadsheet is opened.

Godders199

Active Member
Joined
Mar 2, 2017
Messages
313
Office Version
  1. 2013
Hello, I am looking to automate some VBA to prevent the need for users to remember to run a VBA to update the data within a workbook.

I do not believe i can use task schedulers as all computers have to be turned off when not in use.

Effectively what i am looking for is code that will run the VBA the first time a workbook is opened each month, and a message to pop up to let the user know that this is happening.

Is this possible? if yes any links to examples would be appreciated.
 

Excel Facts

VLOOKUP to Left?
Use =VLOOKUP(A2,CHOOSE({1,2},$Z$1:$Z$99,$Y$1:$Y$99),2,False) to lookup Y values to left of Z values.
In order to know if the spread sheet is updated you could keep the date it was updated in a hidden sheet, I used sheet9 here change to what you want. Then you can check if the current month of is after the month of the last time the file was auto updated.


This should go into the ThisWorkbook module
Code:
Private Sub Workbook_Open()

If Month(Date) > Month(Range("A1")) Then


[COLOR=#008000]    'code to update numbers here[/COLOR]
    Sheets("sheet9").Range("A1") = Date
    MsgBox ("spreadsheet updated")
End If


End Sub
 
Upvote 0
You could use a 'Parameters' sheet where you store the current month number. Lets say in cell A1 you have 11. Then use:

Code:
Private Sub Workbook_Open()

If Sheets("Parameters").Range("A1").Value <> Month(Now) Then
    Sheets("Parameters").Range("A1").Value = Month(Now)
    Call Macro1
End If

End Sub

This will only run if the month is not equal to the cell value and if it does run it updates the cell so it doesnt run again until next month.
 
Upvote 0
That should work. I was thinking of an answer but had not thought of this one.
You could use a 'Parameters' sheet where you store the current month number. Lets say in cell A1 you have 11. Then use:

Code:
Private Sub Workbook_Open()

If Sheets("Parameters").Range("A1").Value <> Month(Now) Then
    Sheets("Parameters").Range("A1").Value = Month(Now)
    Call Macro1
End If

End Sub

This will only run if the month is not equal to the cell value and if it does run it updates the cell so it doesnt run again until next month.
 
Upvote 0
You could use a 'Parameters' sheet where you store the current month number. Lets say in cell A1 you have 11. Then use:

Code:
Private Sub Workbook_Open()

If Sheets("Parameters").Range("A1").Value <> Month(Now) Then
    Sheets("Parameters").Range("A1").Value = Month(Now)
    Call Macro1
End If

End Sub

This will only run if the month is not equal to the cell value and if it does run it updates the cell so it doesnt run again until next month.

Thanks for your help
 
Upvote 0

Forum statistics

Threads
1,225,269
Messages
6,183,975
Members
453,200
Latest member
cthun0117

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