Abstract base classes for making h5py-like objects.
Project description
h5py_like
Some base classes and helper functions for an approximately h5py-like API in python 3.7+.
Use case
You have a library which reads/writes contiguous regions of chunked numeric arrays, and want to make it behave somewhat like h5py.
Not supported
- Empty and scalar data spaces
- Logical indexing
- Broadcasting (other than scalar)
- Dimension scales
Differences from h5py
- Access modes are converted to enums, although they are largely compatible with the
str
forms"x"
is preferred over"w-"
for exclusive creation
Usage
See the trivial HDF5 implementation in the tests package.
Create your own Dataset
, Group
, File
, and AttributeManager
classes,
implementing their abstract methods.
Because File
s should subclass your Group
, the base class here is a mixin.
It should come before the Group
in the MRO.
Methods containing write operations should be given the @mutation
decorator.
This checks their mode
attribute and raises an error if it is readonly.
from h5py_like import DatasetBase, GroupBase, AttributeManagerBase, FileMixin, mutation
class MyDataset(DatasetBase):
# ... implement abstract methods
@mutation
def __setitem__(self, idx, val):
...
class MyGroup(GroupBase):
# ... implement abstract methods
pass
class MyFile(FileMixin, MyGroup):
# ... implement abstract methods
pass
class MyAttributeManager(AttributeManagerBase):
# ... implement abstract methods
pass
Helpers
h5py_like.shape_utils
contains a variety of helper functions,
to simulate numpy's flexibility.
Testing
A suite of tests for basic h5py-like functionality is included.
To use it, you must be using pytest, and define a fixture which yields an instance of your File
implementation.
Then you just need to subclass the provided abstract test classes:
conftest.py
import pytest
@pytest.fixture
def file_():
yield MyFile("my_name")
test_implementation.py
from h5py_like.test_utils import FileTestBase, GroupTestBase, DatasetTestBase, ModeTestBase
# concrete class names must start with Test
class TestFile(FileTestBase):
pass
class TestGroup(GroupTestBase):
pass
class TestDataset(DatasetTestBase):
pass
class TestMode(ModeTestBase):
def factory(self, mode):
# Instantiate your File object in the given mode in a way which is repeatable within a method.
return MyFile(mode)
If your dataset implementation supports chunking and threading, use the ThreadedDatasetTestBase
base class instead.
The provided base classes test some of the expected functionality, even if you don't write any methods in your test classes. You can add more tests if you like, or override those you want to change, or decorate any you to skip or xfail.
The GroupTestBase
provides a group_name
attribute and a self.group(parent)
method for creating a group of that name.
The DatasetTestBase
provides dataset_
name
, shape
, and dtype
, and a self.dataset(parent)
method for making that dataset.
Notes
If you only want to implement part of the h5py-like API, just raise NotImplementedError()
.
Then your classes are being explicit about what they do and don't support.
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
Hashes for h5py_like-0.5.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8b7c42598ea7c71330c94977512c82ca550b927a8b1ee098a6b6592af2c490da |
|
MD5 | 542b17c7b59221249c29950c0eddce73 |
|
BLAKE2b-256 | dbe3495abfd1e432e7c4e38daf39d0f32a5647c6bed47b13fa1837813afba995 |