Yet another way to measure code execution duration using a context
Project description
context-timing
A python context manager for timing of a block. Somewhat similar to contexttimer or timethis.
Uses perf_counter_ns()
underneath.
The goal of this package is not to be extremely accurate or lightweight. Though both should be acceptable.
Use case
Main use case
This package is not intended to measure perfomance like timeit would do. The main use case here is to get a quick way to display how long a block of code takes to execute. For instance if you have a large amount of code that runs, and have a feeling that the duration of some functions could help you understand the behaviour. This package lets you easily add a display of this timing.
How to use
Basic
from context_timing import measure_time
with measure_time():
sleep(1)
Set output steam for multiple calls
from context_timing import measure_time, set_log_func
set_log_func(print)
with measure_time():
sleep(1)
with measure_time():
sleep(2)
Redirect the output for one measurement
import logging
from context_timing import measure_time, set_log_func
set_log_func(print)
with measure_time(logging.info):
sleep(1)
with measure_time():
sleep(2)
In-between timing
The package, similarly to contexttimer
lets you get the time since start, within the context.
from context_timing import measure_time
with measure_time() as m:
sleep(1)
m.print() # ~1s
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for context_timing-0.0.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a1e91668b08875e6f8f7ab415a0cd181c5113bdf143d4b2c1190f560009a3a23 |
|
MD5 | 7c2287b5900e4995e34d26f5dcd5922a |
|
BLAKE2b-256 | 06882479333fc6f17f7761679756053bf736b57261b71c58e28c7c971b512778 |