A python library to compress a dict into a bytearray.
Project description
proJSON
A python library to compress a dict into a bytearray.
Install
pip install proJSON
The Crafter
Types
# Format
"name" : {
"type": type, # Types specified below with arguments
...
}
"intExample" : {
"type": "int", # Set int type
"byte": 1 # Set max int size to 1 byte (int8)
}
"stringExample" : {
"type": "string", # Set string type
"maxlen": 1 # Set max size of string ( the max size of the string is calculated by (2^(8*n)-1). if n is 1 then the max size is 255) (optional defaults to 2)
}
"bytesExample" : {
"type": "bytes", # Set bytes type
"maxlen": 1 # Set max size of string ( the max size of the string is calculated by (2^(8*n)-1). if n is 1 then the max size is 255) (optional defaults to 2)
}
"dirExample" : {
"type": "dir", # Set dir type
"subdirs": {} # A dictionary of int, string and byte types in the format above.
}
"boolExample" : {
"type" : "bool" # Set bool type
}
"listExample" : {
"type" : "list", # Set list type
"subtype": "int", # Set list contents type to an "int"
"maxlen": 1 # The "maxlen" parameter for bytes or str (for "int" maxlen is still used instead of "byte")
}
Don't put a dir in another dir. It won't work
Init
from proJSON import Crafter
schema = {
# See the [types section](###Types) for how to make this.
"intExample" : {
"type": "int",
"byte": 1
},
"stringExample" : {
"type": "string",
"maxlen": 1
},
"bytesExample" : {
"type": "bytes",
"maxlen": 1
},
"dirExample" : {
"type": "dir",
"subdirs": {
"intExample2" : {
"type": "int",
"byte": 1
},
"stringExample2" : {
"type": "string",
"maxlen": 1
},
}
}
}
crafter = Crafter(schema)
Encoding data
exampledata = {
"intExample" : 7,
"stringExample" : "Hello World!",
"bytesExample": b"This is bytes",
"dirExample" : {
"intExample2" : 200,
"stringExample2": "Hello Again!"
}
}
encoded = crafter.encode(exampledata)
print(encoded) # b'\x07\x0cHello World!\x00\rThis is bytes\xc8\x0cHello Again!' (43 bytes)
Decoding data
data = b'\x07\x0cHello World!\x00\rThis is bytes\xc8\x0cHello Again!'
decoded = crafter.decode(data)
print(decoded) # {'intExample': 7, 'stringExample': 'Hello World!', 'bytesExample': b'This is bytes', 'dirExample': {'intExample2': 200, 'stringExample2': 'Hello Again!'}} (154 bytes)
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
proJSON-1.2.7.tar.gz
(4.7 kB
view details)
Built Distribution
File details
Details for the file proJSON-1.2.7.tar.gz
.
File metadata
- Download URL: proJSON-1.2.7.tar.gz
- Upload date:
- Size: 4.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5a9478d8ef9af09a8bc94db4d352b27fa7e6d15fc7b7edd293e1f1bef4e5d1e6 |
|
MD5 | 30db061ca8e6525d18d1f806054e010e |
|
BLAKE2b-256 | 914654177db595d31a71ba572d7f7a5cc3cc40590294c8b13a5629bfde186f63 |
File details
Details for the file proJSON-1.2.7-py3-none-any.whl
.
File metadata
- Download URL: proJSON-1.2.7-py3-none-any.whl
- Upload date:
- Size: 4.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b93de71fbc99dbc2e9e325febcb2073281829735c9a1e23f2351ae8762df859c |
|
MD5 | d71bc5cb6abed3b4d2a1e3378f4aac9b |
|
BLAKE2b-256 | 149dcc04f020b3fcd6caf7affd618f4e01d4600c1b5649faf948037a67f9945b |