Python Data Libraries
Project description
mabel is a Data Engineering platform designed to run in serverless environments.
mabel just runs when you need it, scaling to zero, making it efficient and ideal for deployments to platforms like Kubernetes, GCP Cloud Run, AWS Fargate and Knative.
- Documentation GitHub Wiki
- Bug Reports GitHub Issues
- Feature Requests GitHub Issues
- Source Code GitHub
- Discussions GitHub Discussions
Focus on What Matters
We've built mabel to enable Data Analysts to write complex data engineering tasks quickly and easily, so they could get on with doing what they do best.
from mabel import Reader
data = Reader(dataset="test_data")
print(data.count())
Key Features
- On-the-fly compression
- Low-memory requirements, even with terabytes of data
- Indexing and partitioning of data for fast reads
- Cursors for tracking reading position between processes
- Partial SQL DQL (Data Query Language) support
- Schema and data_expectations validation
Installation
From PyPI (recommended)
pip install --upgrade mabel
From GitHub
pip install --upgrade git+https://github.com/mabel-dev/mabel
A preview release of mabel is available from PyPI
pip install --upgrade mabelbeta
You may need to manually uninstall mabel before the test version will install.
These versions are usually labelled with an a
(signifying alpha status) in the
library version. Alpha versions are more likely to have functional issues.
Guides
Dependencies
- orjson for JSON (de)serialization
- bitarray for handling high density boolean data
- siphashc for non-cryptographic hashing
- pydantic to define internal data models
- zstandard for real-time on disk compression
- LZ4 for real-time in memory compression
- simdjson for fast JSON deserialization
- cython for precompilation
There are a number of optional dependencies which are usually only required for specific features and functionality. These are listed in tests/requirements.txt.
Integrations
mabel comes with adapters for the following data services:
Service | |
---|---|
Google Cloud Storage | |
MinIO | |
AWS S3 | |
Azure Blob Storage | |
Local Storage |
Mabel is extensible with adapters for other data services as required.
Deployment and Execution
mabel supports running on a range of platforms, including:
Platform | |
---|---|
Docker | |
Kubernetes | |
Windows (1) | |
Linux (2) |
1 - Some non-core features are not available on Windows.
2 - Tested on Debian (WSL) and Ubuntu.
How Can I Contribute?
All contributions, bug reports, bug fixes, documentation improvements, enhancements, and ideas are welcome.
If you have a suggestion for an improvement or a bug, raise a ticket or start a discussion.
Want to help build mabel? See the contribution guidance.
License
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 Distributions
Hashes for mabel-0.5.3-cp39-cp39-win_amd64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 071fb76830e0ac35f27b0d91b2f85e4bef4e1728e34f6e9315f7b5cb313cf3dc |
|
MD5 | 86266994a3bd608769b665c93e2b9f47 |
|
BLAKE2b-256 | 2ec2e93176b382d242974b575aea0d49ea5a2f46129b4e58e739701911d1de32 |
Hashes for mabel-0.5.3-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6b1d15331d50e331eb25caf18430f8ef235fa8b578f5d77b8bef7c416810c6f6 |
|
MD5 | a4482c639629b771d56ad68d55c3c557 |
|
BLAKE2b-256 | 0dc9df906dff924e78588713b4fb98191f3e613dc71aa268e79423d7c67a29b0 |
Hashes for mabel-0.5.3-cp39-cp39-macosx_10_15_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | d8cd98aa1ae5ffdd589c0e3319206b4e95880f22fa6273bc4dcd87968fda6cbc |
|
MD5 | d7006f32e73455de84d49ffb822d9185 |
|
BLAKE2b-256 | 969dc7b3dc0afe3b5cb5e4c4ffdb962a092f4bc5292a23e7ba799bb43d819b66 |
Hashes for mabel-0.5.3-cp38-cp38-win_amd64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3468309d7a94d7ddcb660a9adac795775053d5989421e3170698dfecd99e9d77 |
|
MD5 | 71d82cab3efe2bdd50b32deaa23f42ce |
|
BLAKE2b-256 | b225a3ca270a9b505d768195c82d44c623400494041d074f4bd956d72d2943c0 |
Hashes for mabel-0.5.3-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8685b0cfd465f9fbb2c04ec277359c1d5560b1f1030f04fec3e54d600faf2de8 |
|
MD5 | 69778d4ce539b1481b670c3f069b15b2 |
|
BLAKE2b-256 | d8c0db8bf380fa771de23e43a6e1c9c713a726c8d9b9550fc6e4bc488d8b119d |
Hashes for mabel-0.5.3-cp38-cp38-macosx_10_14_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 78d5fe2f47c4dc6b7cc64bd85e9c2279554db7de0417e9379edf8a84e2342536 |
|
MD5 | 3a5c49ed0c6a993311330f76c304244b |
|
BLAKE2b-256 | 26e9d6332266a21a9e603d1e89a5c62f16ea5016b7ace2fcb2bfd8bf4286654d |
Hashes for mabel-0.5.3-cp37-cp37m-win_amd64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | b8e7765f29971840677d11c0b444a0b1265b1450315df5fb89745386a4ed3504 |
|
MD5 | c18f8a2a4dd0cc56d4ac61c49dffa385 |
|
BLAKE2b-256 | 20d104084df47010cd3fa5f70d34768af8d9ddb8e4d060c3461fb29c5ae94d94 |
Hashes for mabel-0.5.3-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | bb0ee1ebe5692b97787bdef078e8fc6fb6d5bf6a6a0d96950d19da451f3e2ba0 |
|
MD5 | 32880449123f34690ee696f8a1e4e22a |
|
BLAKE2b-256 | 183ea4ec5ce60c0bf9fb6badd0418507b664d0aa1cc1fc203260f0382234e5f8 |
Hashes for mabel-0.5.3-cp37-cp37m-macosx_10_14_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e7aa684eb251cdf28f6378674e4384d2c0fbf126c14bc8d17c92ae3ff74c4664 |
|
MD5 | af5318adb1ad1782e135a2369f27adb7 |
|
BLAKE2b-256 | 431ffe25a1a5ded0e32577ba31f7a158937f0afb1f93b9f396760d458a53e608 |