Recompress zarr chunks in-place
Project description
mysquishy
"I shall call him Squishy and he shall be mine and he shall be my Squishy." — Dory
Change the compression of a zarr array in-place.
This works by loading the chunk bytes, decoding them, recoding them, and saving them. At the end, the .zarray file at the root is updated.
Note that this only works for single arrays: there should be a .zarray file at the root. It is left as an exercise for the reader to figure out how to recompress every array in a zarr group.
Contributions are very welcome.
⚠️ BAD SQUISHY! ⚠️
This is currently just a proof of concept and it will leave your zarr arrays in an inconsistent/broken state if it is interrupted! And/or there might be bugs. It makes no effort to account for missing keys, for example. As above, contributions are very welcome but in the meantime be careful! Make a tiny zarr example similar to your data and check that it works fine there before deploying it properly.
Usage
From Python:
nbytes_before, nbytes_after = mysquishy.squish('path/to/array.zarr')
From the command line:
mysquishy path/to/array.zarr
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 mysquishy-0.2.0.tar.gz
.
File metadata
- Download URL: mysquishy-0.2.0.tar.gz
- Upload date:
- Size: 4.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a8ea5b9534b7aa0f8b6acf06a888782d07d69b1c03c025137af8e2c9e12c6756 |
|
MD5 | 6de783a6f0629d77dfb61cf8bf977da8 |
|
BLAKE2b-256 | 038ae80203a432c950b395145db3d6109993723c8ab72e27e267456e0f7304dd |
File details
Details for the file mysquishy-0.2.0-py3-none-any.whl
.
File metadata
- Download URL: mysquishy-0.2.0-py3-none-any.whl
- Upload date:
- Size: 5.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 039ced1445ed6164ebd9a11782ee4a35fe14ad9914caa93c85b192b7f8344ffa |
|
MD5 | 6f0fbb6f9a586e6f8ab1938d96784d02 |
|
BLAKE2b-256 | 894ec39571bb451823126bf2a223f9900d6931cb53da8d60f69ca2352c217d57 |