VBA Code to run on the hour within range of hours

borski88

Board Regular
Joined
Jul 3, 2015
Messages
71
I'd like a macro to be pulled at exactly the start of a new hour between the nightshift hours of 18:00-06:00. I found the following code, but not sure how to make it repeat each hour:

VBA Code:
Sub Timer()
    'first call appropriate procedure
    Call myProcedure
    
    'next, set new calling time
    Application.OnTime TimeValue("18:00:00"), "Timer"
End Sub

Sub myProcedure()

MsgBox "Test Sucessful"

End Sub
 

Excel Facts

Whats the difference between CONCAT and CONCATENATE?
The newer CONCAT function can reference a range of cells. =CONCATENATE(A1,A2,A3,A4,A5) becomes =CONCAT(A1:A5)

mart37

Well-known Member
Joined
Aug 4, 2017
Messages
1,091
Office Version
  1. 2016
Platform
  1. Windows
VBA Code:
t = Now()
h = Hour(t) + 1
m = 0
s = 0
If Not (h > 6 And h < 18) Then  Application.OnTime TimeValue(TimeSerial(h, m, s)), "timer"
 

Watch MrExcel Video

Forum statistics

Threads
1,130,181
Messages
5,640,643
Members
417,159
Latest member
Mayozero

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
Top