Tools for easily working with Zarr groups and arrays
Project description
eZarr
Easily store any Python object inside zarr hierarchies. This package defines proxies for regular Python lists (EZList) and dicts (EZDict), built as wrappers around zarr Arrays and Groups. It also defines a Protocol for writing and loading any object in zarr hierarchies.
EZList
An EZlist is a proxy for a Python list built on top of a zarr.Array. It allows storing mixed arbitrary objects in a 1 dimensional sequence.
Examples
>>> from ezarr import EZList
>>> from pathlib import Path
# EZList creation from a zarr.Array:
>>> EZList(zarr.array([1, 2, 3]))
EZList[1, 2, 3]
# EZList creation from a list:
>>> data = [1, "some text", Path("some/path.txt")]
>>> ez_list = EZList.from_list(data, store={}, name="data")
# ~~ ~~~~ a name for the list inside the store
# |
# or any zarr StoreLike object to store the list
>>> ez_list
EZList[1, 'some text', PosixPath('some/path.txt')]
# EZLists support general list methods:
>>> ez_list[0]
1
>>> del ez_list[1]
>>> ez_list
EZList[1, PosixPath('some/path.txt')]
>>> ez_list.append(3.14)
>>> ez_list
EZList[1, PosixPath('some/path.txt'), 3.14]
>>> ez_list.insert(0, [1, 2, 3])
>>> ez_list
EZList[[1, 2, 3], 1, PosixPath('/some/path.txt'), 3.14]
# EZList save to zarr store:
>>> ez_list.save("path/to/store", name="saved_list")
# EZList load from zarr store:
>>> EZList.open("path/to/store", name="saved_list")
EZList[[1, 2, 3], 1, PosixPath('/some/path.txt'), 3.14]
# EZList conversion to a regular list:
>>> ez_list.copy()
[[1, 2, 3], 1, PosixPath('some/path.txt'), 3.14]
EZDict
An EZDict is a proxy for a Python dict built on top of a zarr.Group. It expands zarr.Groups to store and retrieve arbitrary objects.
Examples
>>> from ezarr import EZDict
# EZdDct creation for a zarr.Group:
>>> EZDict(zarr.open_group({}))
EZDict{}
# EZDict creation for a dict:
>>> data = {"a": 1, "b": [1, 2, 3], "c": {"d": "some text"}}
>>> ez_dict = EZDict.from_dict(data, store={})
# ~~ or any zarr StoreLike object to store the dict into # |
# EZDict lazy representation:
>>> ez_dict
EZDict{
a: 1,
b: [1 2 3],
c: {...} # <-- note the nested dict was not loaded for the representation
}
# EZDict save to zarr store:
>>> ez_dict.save("path/to/store", name="saved_dict")
# EZDict load from zarr store:
>>> EZDict.open("path/to/store", name="saved_dict")
EZDict{
a: 1,
b: [1 2 3],
c: {...}
}
# EZDict conversion to a regular dict:
>>> ez_dict.copy()
{'a': np.int64(1), 'b': array([1, 2, 3]), 'c': {'d': np.str_('some text')}}
SupportsEZReadWrite
The SupportsEZReadWrite protocol, once implemented on an object, allows it to be store in and retrieved from a zarr hierarchy.
@runtime_checkable
class SupportsEZRead(Protocol):
@classmethod
def __ez_read__(cls, grp: zarr.Group) -> Self: ...
@runtime_checkable
class SupportsEZWrite(Protocol):
def __ez_write__(self, grp: zarr.Group) -> None: ...
@runtime_checkable
class SupportsEZReadWrite(SupportsEZRead, SupportsEZWrite, Protocol): ...
This protocol has 2 parts:
SupportsEZReaddefines the classmethod__ez_read__(cls, grp: zarr.Group) -> Selffor reconstructing an object from a zarr.Group.SupportsEZWritedefines the method__ez_write__(self, grp: zarr.Group) -> Nonefor storing an object in a zarr.Group.
Once implemented on an object, this protocol allows that object to be automatically saved and loaded in EZLists and EZDicts.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ezarr-1.3.0.tar.gz.
File metadata
- Download URL: ezarr-1.3.0.tar.gz
- Upload date:
- Size: 47.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.11 {"installer":{"name":"uv","version":"0.9.11"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Manjaro Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1be10d3643367f510a7f3ed2ffa121e0b7e1e9a8b4234b7b62557f45e1bad805
|
|
| MD5 |
9b0545d2fba2e44382db20f768f5f467
|
|
| BLAKE2b-256 |
965d0cbd2c1804586cf410fa7908119a434099be48ca0e32c3eccc9d81fd32d0
|
File details
Details for the file ezarr-1.3.0-py3-none-any.whl.
File metadata
- Download URL: ezarr-1.3.0-py3-none-any.whl
- Upload date:
- Size: 62.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.11 {"installer":{"name":"uv","version":"0.9.11"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Manjaro Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f770e3b019b9d0b9184fe27ac69a9e9623b50f36d781f3b03a451d8f68089191
|
|
| MD5 |
a18e01a297f22865084f59bd5da2aca8
|
|
| BLAKE2b-256 |
dfdaf746fd67c160818be342fed2099dacad24753b469b4d797b371541ff68fd
|