The VBA Timer function returns a Single numeric value representing the number of seconds elapsed since midnight on the current day.
If you want to pause code execution for duration of time check out the VBA Sleep and Application.Wait functions instead.
VBA Timer Function Syntax
The syntax for the Timer function in VBA is:
1 | Timer() |
The Timer function does not accept any parameters.
Example usage
The VBA Timer function can be used in VBA code. Let’s look at some VBA Timer function examples:
Measure elapsed time in Seconds
1 2 3 4 5 6 7 8 9 | Debug.Print Timer() 'Result (at 11:55 AM): 42839,02 Dim startTime as Single startTime = Timer '... Some code here ... Debug.Print Timer - startTime 'Result: time in seconds elapsed |
Measure elapsed time in Hours / Minutes / Seconds
As the VBA Timer function measures time elapsed in seconds, if we want minutes or hours instead we may need to tweak it:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | Dim startTime as Single , timeElapsed as Single , hours as Long , min as Long , seconds as Single startTime = Timer 'Get current time '... Some code here ... timeElapsed = Timer - startTime 'Save the elapsed time to timeElapsed variable 'Extract hours hours = timeElapsed / 3600 timeElapsed = timeElapsed - hours * 3600 'Extract minutes mins = timeElapsed / 60 timeElapsed = timeElapsed - mins * 60 'Extract seconds seconds = timeElapsed Debug.Print "Time Elapsed: " & hours & " hours, " & mins & " minutes, " & seconds & " seconds" |