A package to write schema-aware data pipelines
Project description
SchemaFlow
This is a a package to write data pipelines for data science systematically in Python. Thanks for checking it out.
Check out the very comprehensive documentation here.
The problem that this package solves
A major challenge in creating a robust data pipeline is guaranteeing interoperability between pipes: how do we guarantee that the pipe that someone wrote is compatible with others' pipe without running the whole pipeline multiple times until we get it right?
The solution that this package adopts
This package declares an API to define a stateful data transformation that gives
the developer the opportunity to declare what comes in, what comes out, and what states are modified
on each pipe and therefore the whole pipeline. Check out
tests/test_pipeline.py
or
examples/end_to_end_kaggle.py
Install
pip install schemaflow
or, install the latest (recommended for now):
git clone https://github.com/jorgecarleitao/schemaflow
cd schemaflow && pip install -e .
Run examples
We provide one example that demonstrate the usage of SchemaFlow's API on developing an end-to-end pipeline applied to one of Kaggle's exercises.
To run it, download the data in that exercise to examples/all/
and run
pip install -r examples/requirements.txt
python examples/end_to_end_kaggle.py
You should see some prints to the console as well as the generation of 3 files at
examples/
: two plots and one submission.txt
.
Run tests
pip install -r tests/requirements.txt
python -m unittest discover
Build documentation
pip install -r docs/requirements.txt
cd docs && make html && cd ..
open docs/build/html/index.html
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 schemaflow-0.2.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | db3f4930ab135176b85ba01067b608959f1bcb6ec64bbcbbe510b3ed73f3983c |
|
MD5 | bfc8f9a9559593e1bc58a79adf373e9a |
|
BLAKE2b-256 | 3fb378a1499748782bac31bff0208faca37da748839d04805aaf22ef8454ba1a |