Crate cramjam[][src]

Expand description

CramJam documentation of python exported functions for (de)compression of bytes

Although this documentation is built using Cargo/Rust toolchain, the examples and API represent the usable Python API

In general, the API follows cramjam.<<compression algorithm>>.compress and cramjam.<<compression algorithm>>.decompress as well as compress_into/decompress_into where it takes an input and output combination of any of the following:

Simple Python Example:

>>> data = b'some bytes here'
>>> compressed = cramjam.snappy.compress(data)
>>> decompressed = cramjam.snappy.decompress(compressed)
>>> assert bytes(data) == bytes(decompressed)
>>>

Example of de/compressing into different types.

>>> import numpy as np
>>> from cramjam import snappy, Buffer
>>>
>>> data = np.frombuffer(b'some bytes here', dtype=np.uint8)
>>> data
array([115, 111, 109, 101,  32,  98, 121, 116, 101, 115,  32, 104, 101,
       114, 101], dtype=uint8)
>>>
>>> compressed = Buffer()
>>> snappy.compress_into(data, compressed)
33  # 33 bytes written to compressed buffer
>>>
>>> compressed.tell()  # Where is the buffer position?
33  # goodie!
>>>
>>> compressed.seek(0)  # Go back to the start of the buffer so we can prepare to decompress
>>> decompressed = b'0' * len(data)  # let's write to `bytes` as output
>>> decompressed
b'000000000000000'
>>>
>>> snappy.decompress_into(compressed, decompressed)
15  # 15 bytes written to decompressed
>>> decompressed
b'some bytes here'

Modules

brotli de/compression interface

deflate de/compression interface

cramjam specific Python exceptions

gzip de/compression interface

Module holds native Rust objects exposed to Python, or objects which wrap native Python objects to provide additional functionality or tighter integration with de/compression algorithms.

lz4 de/compression interface

snappy de/compression interface

zstd de/compression interface

Macros

Macro for generating the implementation of de/compression against a variant interface

Macro to convert an error into a specific Python exception.

Enums

Any possible input/output to de/compression algorithms. Typically, as a Python user, you never have to worry about this object. It’s exposed here in the documentation to see what types are acceptable for de/compression functions.

Functions

This autogenerated function is called by the python interpreter when importing the module.