pytictoc contains a class TicToc which replicates the functionality of MATLAB's tic and toc for easily timing sections of code. Under the hood, pytictoc uses the default_timer function from Python's timeit module.
pytictoc can be installed and updated via conda or pip.
pip :
pip install pytictoc
pip install pytictoc --upgrade
conda :
conda install pytictoc -c ecf
conda update pytictoc -c ecf
Basic usage: :
>> from pytictoc import TicToc
>> t = TicToc() #create instance of class
>> t.tic() #Start timer
>> t.toc() #Time elapsed since t.tic()
Elapsed time is 2.612231 seconds.
A string passed to the toc method changes the printed message. This can be useful to differentiate timing of different sections in the same script. :
>> t.toc('Section 1 took')
Section 1 took 16.494467 seconds.
An optional keyword argument restarts the timer (equivalent to t.tic()) after reporting the time elapsed. :
>> t.toc(restart=True)
Elapsed time is 36.986837 seconds.
>>t.toc()
Elapsed time is 2.393425 seconds.
If you want to return the time elapsed to a variable rather than printing it, use the tocvalue method. :
>>spam = t.tocvalue()
>>spam
20.156261717544602
The TicToc class can be used within a context manager as an alternative way to time a section of code. The time taken to run the code inside the with statement will be reported on exit. :
>>with TicToc():
>> spam = [x+1 for x in range(10000)]
Elapsed time is 0.002343 seconds.
pytictoc uses timeit.default_timer to time code. On Python 3.3 and later, this is an alias for time.perf_counter. On earlier versions of Python it is an alias for the most precise timer for a given system.
To see which function is being used: :
>>import pytictoc
>>pytictoc.default_timer
<function time.perf_counter>
You can change the timer by simple assignment. :
>>import time
>>pytictoc.default_timer = time.clock
>>pytictoc.default_timer
<function time.clock>