Functions for decomposing nonnegative integers according to various unit scales and also parsing support for values written in scales.
Project description
Functions for decomposing nonnegative integers according to various unit scales and also parsing support for values written in scales.
Latest release 20250915: Drop slots=True from dataclass, too new.
Presupplied scales:
BINARY_BYTES_SCALE: Binary units of (B)ytes, KiB, MiB, GiB etc.DECIMAL_BYTES_SCALE: Decimal units of (B)ytes, KB, MB, GB etc.DECIMAL_SCALE: Unit suffixes K, M, G etc.TIME_SCALE: Units of (s)econds, (m)inutes, (h)ours, (d)ays and (w)eeks.UNSCALED_SCALE: no units
Short summary:
decimal: Decompose a nonnegative integerninto human decimal counts (kilo etc).decompose: Decompose a nonnegative integerninto counts by unit fromscale. Returns aDecomposedlist of(modulus,UnitStep)in order from smallest unit upward.decompose_time: OBSOLETE version of human_time, suggestion: human_time(n).Decomposed: A list of(modulus,UnitStep)2-tuples representing a decomposed value.geek: Decompose a nonnegative integerninto geek bytes sizes (kibibytes etc).geek_bytes: Decompose a nonnegative integerninto geek bytes sizes (kibibytes etc).human: Decompose a nonnegative integerninto human decimal counts (kilo etc).human_bytes: Decompose a nonnegative integerninto human bytes sizes (kilobytes etc).human_time: Decompose a nonnegative integerninto human time (hours etc).multiparse: Parse an integer followed by an optional scale and return computed value. Returns the parsed value and the new offset.parse: Parse an integer followed by an optional scale and return computed value. Returns the parsed value and the new offset. This is a shim forUnitScale.get_term(s,offset).transcribe: Transcribe a nonnegative integernagainstscale. This is just a shim forUnitScale.transcribe, itself a shim forDecomposed.__str__.transcribe_bytes_decompose: OBSOLETE version of transcribe_bytes_decompose, suggestion: transcribe(n,'decimal') or str(human(n)).transcribe_bytes_geek: OBSOLETE version of transcribe_bytes_geek, suggestion: transcribe(n,'geek_bytes',1) or str(geek_bytes(n)).transcribe_time: OBSOLETE version of transcribe_time, suggestion: transcribe(n,'human_time',3) or str(human_time(n)).UnitScale: A representation of a unit scale as a list of unit terms and scale factors.UnitStep: A scale step for a unit scale. The lastUnitStepin a scale should havefactor=0.
Module contents:
-
decimal(n): Decompose a nonnegative integerninto human decimal counts (kilo etc). -
decompose(n, scale: cs.units.UnitScale) -> cs.units.Decomposed: Decompose a nonnegative integerninto counts by unit fromscale. Returns aDecomposedlist of(modulus,UnitStep)in order from smallest unit upward.Parameters:
n: a nonnegative integer.scale: aUnitScale(or promotable)
-
decompose_time(n): OBSOLETE version of human_time, suggestion: human_time(n)Decompose a nonnegative integer
ninto human time (hours etc). -
class Decomposed(builtins.list): A list of(modulus,UnitStep)2-tuples representing a decomposed value.
Decomposed.__float__(self) -> float:
The total value as a float.
Decomposed.__int__(self) -> int:
The total value as an int.
Decomposed.__str__(self, max_parts=None, *, skip_zero=False, sep='', no_pad=False) -> str:
Transcribe a nonnegative integer n against scale.
Parameters:
max_parts: the maximum number of components to transcribe.skip_zero: omit components of value 0.sep: separator between words, default:''.
Decomposed.sum(self):
Return the total value represented by this Decomposed.
-
geek(n): Decompose a nonnegative integerninto geek bytes sizes (kibibytes etc). -
geek_bytes(n): Decompose a nonnegative integerninto geek bytes sizes (kibibytes etc). -
human(n): Decompose a nonnegative integerninto human decimal counts (kilo etc). -
human_bytes(n): Decompose a nonnegative integerninto human bytes sizes (kilobytes etc). -
human_time(n): Decompose a nonnegative integerninto human time (hours etc). -
multiparse(s, scales, offset=0): Parse an integer followed by an optional scale and return computed value. Returns the parsed value and the new offset.Parameters:
s: the string to parse.scales: an iterable of scale arrays of (factor, unit_name).offset: starting position for parse.
-
parse(s: str, scale: cs.units.UnitScale, offset=0): Parse an integer followed by an optional scale and return computed value. Returns the parsed value and the new offset. This is a shim forUnitScale.get_term(s,offset).Parameters:
s: the string to parse.scale: a scale array of (factor, unit_name).offset: starting position for parse.
-
transcribe(n, scale: cs.units.UnitScale, max_parts=None, *, skip_zero=False, sep='', no_pad=False): Transcribe a nonnegative integernagainstscale. This is just a shim forUnitScale.transcribe, itself a shim forDecomposed.__str__.Parameters:
n: a nonnegative integer.scale: aUnitScale(or promotable)max_parts: the maximum number of components to transcribe.skip_zero: omit components of value 0.sep: separator between words, default:''.
-
transcribe_bytes_decompose(n, max_parts=1, **kw): OBSOLETE version of transcribe_bytes_decompose, suggestion: transcribe(n,'decimal') or str(human(n))Transcribe a nonnegative integer
nagainstDECIMAL_BYTES_SCALE. -
transcribe_bytes_geek(n, max_parts=1, **kw): OBSOLETE version of transcribe_bytes_geek, suggestion: transcribe(n,'geek_bytes',1) or str(geek_bytes(n))Transcribe a nonnegative integer
nagainstBINARY_BYTES_SCALE. -
transcribe_time(n, max_parts=3, **kw): OBSOLETE version of transcribe_time, suggestion: transcribe(n,'human_time',3) or str(human_time(n))Transcribe a nonnegative integer
nagainstTIME_SCALE. -
class UnitScale(cs.deco.Promotable): A representation of a unit scale as a list of unit terms and scale factors.
UnitScale.decompose(self, n) -> cs.units.Decomposed:
Decompose a nonnegative integer n into counts by unit.
Returns a Decomposed list of (modulus,UnitStep) in order from smallest unit upward.
Parameters:
n: a nonnegative integer.scale: a sequence ofUnitStepor(factor,unit[,max_width])where factor is the size factor to the following scale item andunitis the designator of the unit.
UnitScale.from_str(scale_name: str):
Return a UnitScale from its name.
UnitScale.get_term(self, s: str, offset=0) -> Tuple[int, int]:
Parse a decimal values possibly followed by a unit name from s at offset.
Return a (value,offset) 2-tuple.
Parameters:
s: the string to parse.scale: a scale array of (factor, unit_name).offset: starting position for parse.
UnitScale.transcribe(self, n, max_parts=None, *, skip_zero=False, sep='', no_pad=False):
Transcribe n according to this scale.
Parameters are passed to Decomposed.__str__.
UnitStep.__iter__(self):
for unpacking assignment
Release Log
Release 20250915: Drop slots=True from dataclass, too new.
Release 20250601: Fix @OBSOLETE definition of decompose_time.
Release 20250528:
- Big refactor so that we can just str() the result of a decompose.
- New Decomposed, UnitStep, UnitScale classes.
Release 20220311: Naming update: rename human* to decompose* to clarify that these decompose a number into a sequence of values on a scale.
Release 20210809: Update parse() for new structure in the scale definitions.
Release 20210717: transcribe: pad units by default, produces less jitter in dynamic displays like progress bars.
Release 20201025: transcribe: use str(count_i), not str(count) if count == count_i.
Release 20200718: Use str.isalpha to recognise "unit" words instead of string.ascii_letters (uses new cs.lex.get_chars "callable gochars" mode).
Release 20200626: transcribe: use "%.1f" to format the count if it is not == int(count) ==> a float-with-fraction.
Release 20200613: New UNSCALED_SCALE for no units.
Release 20190220: Dependency fix.
Release 20181228: Initial PyPI release.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cs_units-20250915.tar.gz.
File metadata
- Download URL: cs_units-20250915.tar.gz
- Upload date:
- Size: 5.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8e81fef181deaea9716a8facbdddd0b38f29fe3a7f58c2dc0a678dea7d82e35c
|
|
| MD5 |
833a32e68f0759f8711990cbbad22672
|
|
| BLAKE2b-256 |
c1d403e52fdfb8417f1eecbfe14ba3b61c248956d99e17eda7267d65f5d73346
|
File details
Details for the file cs_units-20250915-py2.py3-none-any.whl.
File metadata
- Download URL: cs_units-20250915-py2.py3-none-any.whl
- Upload date:
- Size: 6.9 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8965c7bd816197193c46ce095d38b4ea95a9c63fbcb8ffa45ddcf78de6b1b404
|
|
| MD5 |
80ffff8447cb2dc91fc584715810e735
|
|
| BLAKE2b-256 |
37f32032b0da0c57af3fac9223d1c81fb41a7ebd1f036cbffc98fc5c67daf231
|