Skip to main content

Conveniently measures the time of loops, contexts and functions.

Project description

Horology

PyPI version tests codeql PythonVersion OperatingSystems Downloads License: MIT

Conveniently measures the time of your loops, contexts and functions.

Installation

horology version compatible python
1.4.2 3.10-3.14
1.4.1 3.10-3.13
1.4 3.10-3.12
1.3 3.8-3.11
1.2 3.6-3.9
1.1 3.6-3.8

Horology can be installed with PIP. It has no dependencies.

pip install horology

Usage

The following 3 tools will let you measure practically any part of your Python code.

Timing an iterable (list, tuple, generator, etc)

Quick example

from horology import Timed

animals = ['cat', 'dog', 'crocodile']

for x in Timed(animals):
    feed(x)

Result:

iteration    1: 12.0 s
iteration    2: 8.00 s
iteration    3: 100 s

total 3 iterations in 120 s
min/median/max: 8.00/12.0/100 s
average (std): 40.0 (52.0) s

Customization

You can specify where (if at all) you want each iteration and summary to be printed, eg.:

for x in Timed(animals, unit='ms',
               iteration_print_fn=logger.debug,
               summary_print_fn=logger.info):
    feed(x)

Timing a function with a @timed decorator

Quick example

from horology import timed


@timed
def foo():
    ...

Result:

>>> foo()
foo: 7.12 ms

Customization

Chose time unit and name:

@timed(unit='s', name='Processing took ')
def bar():
    ...

Result:

>>> bar()
Processing took 0.185 s

Timing part of code with a Timing context

Quick example

Just wrap your code using a with statement

from horology import Timing

with Timing(name='Important calculations: '):
    ...

Result:

Important calculations: 12.4 s

Customization

You can suppress default printing and directly use measured time (also within context)

with Timing(print_fn=None) as t:
    ...

make_use_of(t.interval)

Time units

Time units are by default automatically adjusted, for example you will see foo: 7.12 ms rather than foo: 0.007 s. If you don't like it, you can override this by setting the unit argument with one of these names: ['ns', 'us', 'ms', 's', 'min', 'h', 'd'].

Contributions

Contributions are welcomed, see contribution guide.

Internals

Horology internally measures time with perf_counter which provides the highest available resolution, see docs.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

horology-1.4.2.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

horology-1.4.2-py3-none-any.whl (9.1 kB view details)

Uploaded Python 3

File details

Details for the file horology-1.4.2.tar.gz.

File metadata

  • Download URL: horology-1.4.2.tar.gz
  • Upload date:
  • Size: 6.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.11.5 Windows/10

File hashes

Hashes for horology-1.4.2.tar.gz
Algorithm Hash digest
SHA256 913536ed4ad4b33fb4d4fca564647c1c03c1de75525b91217b1e782405a6ca39
MD5 f954252f8d9ea1a5d2b03518d5bd8849
BLAKE2b-256 4c432aa875fc7cde517fc42ad11d38f977439c491336fb1217877767585f0101

See more details on using hashes here.

File details

Details for the file horology-1.4.2-py3-none-any.whl.

File metadata

  • Download URL: horology-1.4.2-py3-none-any.whl
  • Upload date:
  • Size: 9.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.11.5 Windows/10

File hashes

Hashes for horology-1.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 37f107450fe8ce1e8adc8b85f8f3eff4609d6ced3d76cb381c219e1ab3fb1b1d
MD5 ad043c88cf1f65bcc7fe530af348c956
BLAKE2b-256 022ea2aa307057c4be927a894141ec2d42c62d1f656bb413fa81a5b44edf2761

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page