Skip to main content

High performance parallel reading of HDF5 files using PyTables, multiprocessing, and shared memory.

Project description

multitables is a python library designed for high speed access to HDF5 files. Access to HDF5 is provided by the PyTables library (tables). Multiple processes are launched to read a HDF5 in parallel, allowing concurrent decompression. Data is streamed back to the invoker by use of shared memory space, removing the usual multiprocessing communication overhead.

The data is organised by rows of an array (elements of the outer-most dimension), and groups of these rows form blocks. By default, there is no guarantee on the ordering of the rows and/or blocks returned to the user, due to the concurrent nature of the library. They are returned as they become available. On-disk ordering can be forced using the ordered option, which may result in a performance penalty.

Performance gains of at least 2x can be achieved when reading from an SSD.


This software is distributed under the MIT licence. See the LICENSE.txt file for details.


pip install multitables

multitables depends on tables (the pytables package) and numpy. The package is compatible with the latest versions of python 2 and 3.

Quick start

import multitables
stream = multitables.Streamer(filename='/path/to/h5/file')
for row in stream.get_generator(path='/internal/h5/path'):


See the how-to for more in-depth documentation, and the unit tests for complete examples.


Online documentation is available. A how to gives a basic overview of the library. A benchmark tests the speed of the library using various compression algorithms and hardware configurations.

Offline documentation can be built from the docs folder using sphinx.

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for multitables, version 1.1.1
Filename, size File type Python version Upload date Hashes
Filename, size multitables-1.1.1-py2.py3-none-any.whl (11.1 kB) File type Wheel Python version py2.py3 Upload date Hashes View

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring DigiCert DigiCert EV certificate Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page