Skip to main content

A progress tracker with methods for throughput, ETA and update notification; also a compound progress meter composed from other progress meters.

Project description

A progress tracker with methods for throughput, ETA and update notification; also a compound progress meter composed from other progress meters.

Latest release 20230401: progressbar, BaseProgress.iterbar: use @uses_upd to provide a context Upd instance.

Function auto_progressbar(*da, **dkw)

Decorator for a function accepting an optional progress keyword parameter. If progress is None and the default Upd is not disabled, run the function with a progress bar.

Class BaseProgress

The base class for Progress and OverProcess with various common methods.

Note that durations are in seconds and that absolute time is in seconds since the UNIX epoch (the basis of time.time()).

Method BaseProgress.__init__(self, name=None, start_time=None, units_scale=None): Initialise a progress instance.

Parameters:

  • name: optional name
  • start_time: optional UNIX epoch start time, default from time.time()
  • units_scale: a scale for use with cs.units.transcribe, default BINARY_BYTES_SCALE

Class CheckPoint(builtins.tuple)

CheckPoint(time, position)

Method CheckPoint.__new__(_cls, time, position): Create new instance of CheckPoint(time, position)

Class OverProgress(BaseProgress)

A Progress-like class computed from a set of subsidiary Progresses.

AN OverProgress instance has an attribute notify_update which is a set of callables. Whenever the position of a subsidiary Progress is updated, each of these will be called with the Progress instance and None.

Example:

>>> P = OverProgress(name="over")
>>> P1 = Progress(name="progress1", position=12)
>>> P1.total = 100
>>> P1.advance(7)
>>> P2 = Progress(name="progress2", position=20)
>>> P2.total = 50
>>> P2.advance(9)
>>> P.add(P1)
>>> P.add(P2)
>>> P1.total
100
>>> P2.total
50
>>> P.total
150
>>> P1.start
12
>>> P2.start
20
>>> P.start
0
>>> P1.position
19
>>> P2.position
29
>>> P.position
16

Class Progress(BaseProgress)

A progress counter to track task completion with various utility methods.

Example:

>>> P = Progress(name="example")
>>> P                         #doctest: +ELLIPSIS
Progress(name='example',start=0,position=0,start_time=...,throughput_window=None,total=None):[CheckPoint(time=..., position=0)]
>>> P.advance(5)
>>> P                         #doctest: +ELLIPSIS
Progress(name='example',start=0,position=5,start_time=...,throughput_window=None,total=None):[CheckPoint(time=..., position=0), CheckPoint(time=..., position=5)]
>>> P.total = 100
>>> P                         #doctest: +ELLIPSIS
Progress(name='example',start=0,position=5,start_time=...,throughput_window=None,total=100):[CheckPoint(time=..., position=0), CheckPoint(time=..., position=5)]

A Progress instance has an attribute notify_update which is a set of callables. Whenever the position is updated, each of these will be called with the Progress instance and the latest CheckPoint.

Progress objects also make a small pretense of being an integer. The expression int(progress) returns the current position, and += and -= adjust the position.

This is convenient for coding, but importantly it is also useful for discretionary use of a Progress with some other object. If you want to make a lightweight Progress capable class you can set a position attribute to an int and manipulate it carefully using += and -= entirely. If you decide to incur the cost of maintaining a Progress object you can slot it in:

# initial setup with just an int
my_thing.amount = 0

# later, or on some option, use a Progress instance
my_thing.amount = Progress(my_thing.amount)

Method Progress.__init__(self, name: Optional[str] = None, *, position: Optional[float] = None, start: Optional[float] = None, start_time: Optional[float] = None, throughput_window: Optional[int] = None, total: Optional[float] = None, units_scale=None): Initialise the Progesss object.

Parameters:

  • position: initial position, default 0.
  • name: optional name for this instance.
  • start: starting position of progress range, default from position.
  • start_time: start time of the process, default now.
  • throughput_window: length of throughput time window in seconds, default None.
  • total: expected completion value, default None.

Function selftest(argv)

Exercise some of the functionality.

Release Log

Release 20230401: progressbar, BaseProgress.iterbar: use @uses_upd to provide a context Upd instance.

Release 20230212: BaseProgress: new update_period=0.2 parameter to constraint updates by elapsed time.

Release 20221207:

  • BaseProgress.format_counter: accept arbitrary keyword arguments to pass to cs.units.transcribe.
  • Progress.init: accept floats instead of just ints.

Release 20220918: Progress.iterbar: wrap the iteration in a try/finally for cleanup.

Release 20211208:

  • Progress.init: make the first optional positional parameter be "name", make other parameters keyword only.
  • Progress.bar: make "label" the first optional positional parameter, make others keyword only.

Release 20210803:

  • progressbar,iterbar: accept optional RunState to cancel iteration.
  • BaseProgress.iterbar: make update_min_size properly optional, was making update_frequency ineffective.

Release 20210730: When there is no total just report position and no ETA.

Release 20210717: Minor tweaks.

Release 20210316:

  • Progress.iterbar: only update the status line once per iteration, either before or after the yield according to incfirst.
  • Progress.iterbar: fix the meaning of update_frequency to count iterations, add update_min_size to count progress advance.

Release 20210306: progressbar: accept new optional position parameter, used to initialise the Progress.

Release 20201102.1: DISTINFO: fix module dependencies.

Release 20201102:

  • Format/layout changes for the default status line.
  • Progress.throughtput_recent: return None if no new positions beyond the starting position.
  • BaseProgress.status: accept label=None (default to self.name) and width=UpdProxy (uses width.width).
  • BaseProgress.status: new optional window parameter, default 5, defining the recent throughput window size in seconds.
  • A few bugfixes.

Release 20201025:

  • Some formatting improvements.
  • BaseProgress.bar: new insert_pos parameter to position the progress bar, default still 1.
  • BaseProgress.bar: new deferred parameter putting off the status bar until the first update.
  • BaseProgress.bar: accept new optional proxy parameter to use (and not delete) an existing UpdProxy for display.
  • Progress.text_pos_of_total: new pos_first=False parameter, rendering the total before the position by default (less progress bar noise).
  • New @auto_progressbar decorator to provide a progress bar and initialise progress= parameter to functions which can use a Progress for reporting.
  • Assorted fixes.

Release 20200718.3: BaseProgress.bar, progressbar: new optional report_print parameter for reporting on completion.

Release 20200718.2: Bugfix: BaseProgress.status: handle throughput=0 when total=None.

Release 20200718.1: BaseProgress.bar, progressbar: new optional update_frequency parameter for less frequent updates.

Release 20200718:

  • Readability improvement for default status line.
  • progressbar: default units_scale=UNSCALED_SCALE.

Release 20200716.1: BaseProgress.status: round throughput to an int if >=10.

Release 20200716:

  • BaseProgress.status: distinguish "idle" (position >= total) from "stalled" (position < total).
  • BaseProgress.status: make the status very short if the progress is idle.

Release 20200627:

  • BaseProgress.status: handle throughput=None (before any activity).
  • BaseProgress: drop count_of_total_bytes_text, superceded by format_counter (which honours the units_scale).

Release 20200626:

  • New Progress.bar generator method iterating over an iterable while displaying a progress bar.
  • New convenience function progressbar(it,...) which rolls its own Progress instance.
  • Progress: always support a throughput window, default to DEFAULT_THROUGHPUT_WINDOW = 5s.
  • Improve the default progress bar render returned by Progress.status().

Release 20200613:

  • BaseProgress, Progress and OverProgress now accept an optional units_scale, such as cs.units.UNSCALED_SCALE, to use when expressing progress - the default remains BINARY_SCALE.
  • New arrow(), format_counter() and text_pos_of_total() methods to produce components of the status string for tuning or external reuse.

Release 20200520: OverProgress: throughput and eta implementations.

Release 20200129.3: Test version machinery again.

Release 20200129.2: set version to '20200129.2'

Release 20200129.1: Dummy release to test new version.

Release 20200129: New Progress.count_of_total_bytes_text property presenting "3kB/40MB" style text.

Release 20190812:

  • New OverProgress class which is a composite of a set of subsidiary Progress instances.
  • Assorted other small updates.

Release 20190220:

  • Progress: be somewhat like an int.
  • New status() method returning a convenient one line progress status report.

Release 20180703.2: Progress: make .total into a property in order to fire the update notifications.

Release 20180703.1: Progress: additions and changes to API: new .ratio, .elapsed_time, rename .projected to .remaining_time.

Release 20180703: Initial release of cs.progress.

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

cs.progress-20230401.tar.gz (18.2 kB view details)

Uploaded Source

Built Distribution

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

cs.progress-20230401-py3-none-any.whl (14.2 kB view details)

Uploaded Python 3

File details

Details for the file cs.progress-20230401.tar.gz.

File metadata

  • Download URL: cs.progress-20230401.tar.gz
  • Upload date:
  • Size: 18.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for cs.progress-20230401.tar.gz
Algorithm Hash digest
SHA256 22d6f9b8e55e579b43baa908182b5429e38bdc2c2fd7b6167847557898f8f6b2
MD5 2aff43cef95ad2fecfd1dba5df30e13d
BLAKE2b-256 d05732aa2e0d80e10dc311d1e01243c1eced822382fd5da9717287a55f9fb225

See more details on using hashes here.

File details

Details for the file cs.progress-20230401-py3-none-any.whl.

File metadata

  • Download URL: cs.progress-20230401-py3-none-any.whl
  • Upload date:
  • Size: 14.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for cs.progress-20230401-py3-none-any.whl
Algorithm Hash digest
SHA256 6a5b3f7c6312d78af4fa7d66dd2d2efc6cdac19f8840c417f025085b65d953ab
MD5 dccc523e974326369e95b58d5482cba0
BLAKE2b-256 25502c4bb96e202d98648d609cfa423c435544ecf83aefe266d4ff62b05dbe28

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