Python library for general Base-N encodings.
Project description
bases
: a Python library for general Base-N encodings.
Table of Contents
Install
You can install this package with pip
:
pip install bases
Usage
The core functionality of the library is performed by the encode
and decode
methods of base encodings, instances of BaseEncoding
(or, more precisely, of its concrete subclasses).
Common encodings are associated to pre-defined constants:
>>> from bases import base32
>>> base32
FixcharBaseEncoding(
StringAlphabet('ABCDEFGHIJKLMNOPQRSTUVWXYZ234567',
case_sensitive=False),
pad_char='=', padding='include')
The encode
method can be used to encode bytestrings into strings:
>>> b = bytes([70, 98, 190, 187, 66, 224, 178])
>>> base32.encode(b)
'IZRL5O2C4CZA===='
The decode
method can be used to decode strings into bytestrings:
>>> s = 'IZRL5O2C4CZA===='
>>> list(base32.decode(s))
[70, 98, 190, 187, 66, 224, 178]
The get(name)
, has(name)
, make(...)
and table(prefix="")
functions provide an interface for the programmatic management of encodings.
The get(name) function can be used to obtain an existing encoding by name:
>>> import bases
>>> bases.get("base32")
FixcharBaseEncoding(
StringAlphabet('ABCDEFGHIJKLMNOPQRSTUVWXYZ234567',
case_sensitive=False),
pad_char='=', padding='include')
The make(...) function can be used to obtain create a new encoding from a given alphabet, encoding kind and options:
>>> bases.make("0123", kind="zeropad-enc", block_nchars=4, name="base4")
ZeropadBaseEncoding(StringAlphabet('0123'), block_nchars=4)
The optional keyword argument name
can be used to register with the library for future retrieval.
The has(name) function can be used to check whether an encoding exists by a given name:
>>> bases.has("base4")
True
The table(prefix="") function can be used to iterate through the existing encoding, optionally filtering by name prefix:
>>> dict(bases.table(prefix="base32"))
{'base32': FixcharBaseEncoding(
StringAlphabet('ABCDEFGHIJKLMNOPQRSTUVWXYZ234567',
case_sensitive=False),
pad_char='=', padding='include'),
'base32hex': FixcharBaseEncoding(
StringAlphabet('0123456789ABCDEFGHIJKLMNOPQRSTUV',
case_sensitive=False),
pad_char='=', padding='include'),
'base32z': FixcharBaseEncoding(
StringAlphabet('ybndrfg8ejkmcpqxot1uwisza345h769',
case_sensitive=False))
}
For further information, please refer to the API documentation.
API
The API documentation for this package is automatically generated by pdoc.
Contributing
Please see the contributing file.
License
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
File details
Details for the file bases-0.0.0.tar.gz
.
File metadata
- Download URL: bases-0.0.0.tar.gz
- Upload date:
- Size: 31.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e91cda5f3b4daccc7306b3a0bf7e72fb141bc2b1dfeed7a4d002f85d9a6015a4 |
|
MD5 | 7ed23668d21c556bef928027fd84b2dc |
|
BLAKE2b-256 | 16a3bad53e41dafd2bc3ff3160a9dc795e102e416ad5a4a34af05e841e18d859 |
File details
Details for the file bases-0.0.0-py3-none-any.whl
.
File metadata
- Download URL: bases-0.0.0-py3-none-any.whl
- Upload date:
- Size: 33.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 22302daf261885cb832ae393380e572d2060f21bd5bde92658120438eb2e6848 |
|
MD5 | 5fd00898026a7ca211ed94630edaeece |
|
BLAKE2b-256 | 14ac557c15fadddbd5c453e4980f78362d998597b1c9db361087342ea270a15f |