This is for representation of Python data (int, bytes, str) in the desired base system, like base62 system.
Project description
This module is for expressing Python data in the desired base system, such as 62 base system.
Introduce
It supports up to 62 base systems that can be expressed only with digits and case sensitive alphabets.
This module was developed to make it easier to use for URLs or other data fields requiring length restrictions by expressing large numbers or hash values to a shorter length.
You can also encode strings or decode encoded strings. (Strings are not guaranteed to be shortened.)
It started with inspiration from base62 and numpy.base_repr aim to be universally used in multiple systems such as base36 in systems where base62 cannot be applied because it is case-insensitive systems.
Installing Base Repr
Base Repr is available on PyPI:
$ python -m pip install base-repr
Base Repr supports Python 3.6+
How to use
Using functions
>>> import base_repr
# Number to string representation
>>> base_repr.int_to_repr(1234, base=62)
'Ju'
>>> base_repr.repr_to_int('Ju', base=62)
1234
# Bytes to string representation
# bytes([1, 2, 3, 4]) == b'\x01\x02\x03\x04'
>>> base_repr.bytes_to_repr(bytes([1, 2, 3, 4]), base=62, byteorder='little')
'4YPMP'
>>> base_repr.repr_to_bytes('4YPMP', base=62, byteorder='little')
b'\x01\x02\x03\x04'
# sha256
import hashlib
# hashlib.sha256(b'Hello World!').hexdigest() == '7f83b1657ff1fc53b92dc18148a1d65dfc2d4b1fa3d677284addd200126d9069'
>>> base_repr.bytes_to_repr(hashlib.sha256(b'Hello World!').digest(), base=62, byteorder='little')
'P20z9unz25ZdkS9kKi65j9Rb8jqP5knHG08sDpvsQDn'
# string
>>> base_repr.str_to_repr('Hello', base=62, byteorder='little', encoding='utf-8')
'8QMwioi'
>>> base_repr.repr_to_str('8QMwioi', base=62, byteorder='little', encoding='utf-8')
'Hello'
Using class
You can use classes to reduce repetitive parameters.
>>> from base_repr import Base62
>>> base62 = Base62(byteorder='little', encoding='utf-8')
>>> base62.bytes_to_repr(bytes([1, 2, 3, 4]))
'4YPMP'
>>> base62.repr_to_bytes('4YPMP')
b'\x01\x02\x03\x04'
>>> base62.to_repr('int or bytes or str')
'3xDXjUL88hX1Dq95EbXKCI7cOP'
You can also inherit a class to create and use the desired base system.
>>> from base_repr import BaseRepr
>>> class Base36(BaseRepr):
... def __init__(self, padding: int = 0, byteorder: str = sys.byteorder, encoding: str = 'utf-8'):
... super().__init__(36, padding, byteorder, encoding)
>>> base = Base36(padding=0, byteorder='big', encoding='utf-8')
>>> base.int_to_repr(1234)
'YA'
>>> base.repr_to_int('YA')
1234
Base62 and Base36 are already defined in module and ready to use.
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
Built Distribution
File details
Details for the file base_repr-1.0.1.tar.gz
.
File metadata
- Download URL: base_repr-1.0.1.tar.gz
- Upload date:
- Size: 5.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/52.0.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.9.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2cd04894e4579823134b3d020360136fd140bf8b3807ab9dc8bbd92f5feec2d0 |
|
MD5 | 911981ff3802a1b9bf9bce6fd795a18d |
|
BLAKE2b-256 | 7fc5dd7c6276cf1dbe03f181be9a2d8b57457045dd0b539372fc7341b4225796 |
File details
Details for the file base_repr-1.0.1-py3-none-any.whl
.
File metadata
- Download URL: base_repr-1.0.1-py3-none-any.whl
- Upload date:
- Size: 7.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/52.0.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.9.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5ed04111e0bdb3275e09b5d96c379717b702f09f9315b83578aaf953ee27e27f |
|
MD5 | e95f0b7f0beffa99011bfd76cec17450 |
|
BLAKE2b-256 | 6d60fecc2c90fe2a7afaa8f44034e599d7f0ef801f1d32aeaa874ef5503542d6 |