wraptimer
An amazing alternative to Python's builtin timeit
module that allows for high resolution timing of functions as well as in-depth line-by-line timing. It also exposes convenient classes to measure execution time for any arbitrary code.
Sync function example
import time
from wraptimer import TimeIt
timeit = TimeIt()
@timeit.byline
def test_by_line():
a = 10
b = 20
time.sleep(0.8)
c = a + b
return [a, b, c]
test_by_line()
data:image/s3,"s3://crabby-images/9e7c7/9e7c7a64d2b17b0f7df87f6f70f407fb2349a1d7" alt=""
Async function example
import asyncio
from wraptimer import TimeIt
timeit = TimeIt()
@timeit.byline
async def test_by_line_async():
a = 10
b = 20
await asyncio.sleep(1.25)
return [a, b]
asyncio.run(test_by_line_async())
data:image/s3,"s3://crabby-images/c2f00/c2f00b8e0cb224eae2edb31a43e5a899e6f8f836" alt=""
Don't need Line-by-line tracing?
Use @timeit.func
if you do not want to print line-by-line durations.
...
@timeit.func
async def test_by_line_async():
a = 10
b = 20
await asyncio.sleep(1.25)
return [a, b]
data:image/s3,"s3://crabby-images/66356/663565f2412a6dda4da1f13b753c41efb63adbcf" alt=""
Read the documentation
For more about wraptimer, Read The Documentation