No project description provided
Project description
omnipy-examples
Example projects that that makes use of the omnipy package for type-driven, scalable and interoperable data wrangling!
Main installation instructions
- Install:
pip install omnipy-examples
- Run example scripts:
- Example:
omnipy-examples isajson
- For help on the command line interface:
omnipy-examples --help
- For help on a particular example:
omnipy-examples isajson --help
- Example:
Output of flow runs
The output will by default appear in the data
directory, with a timestamp.
- It is recommended to install a file viewer that are capable of browsing tar.gz files. For instance, the "File Expander" plugin in PyCharm is excellent for this.
- To unpack the compressed files of a run on the command line (just make sure to replace the datetime string from this example):
for f in $(ls data/2023_02_03-12_51_51/*.tar.gz); do mkdir ${f%.tar.gz}; tar xfzv $f -C ${f%.tar.gz}; done
Run with the Prefect engine
Omnipy is integrated with the powerful Prefect data flow orchestration library.
- To run an local example using the
prefect
engine, e.g.:omnipy-examples --engine prefect isajson
- After completion of some runs, you can check the flow logs and orchestration options in the Prefect UI:
prefect server start
To set up a kubernetes-based deployment on our NIRD test setup, run e.g.:
prefect config set PREFECT_API_URL=https://prefect.fairtracks.sigma2.no/api
prefect deploy -n isajson
The configuration of this job is found in the file prefect.yaml
.
More info on Prefect configuration will come soon...
Development setup
-
Install Poetry:
curl -sSL https://install.python-poetry.org | python3 -
-
Install dependencies:
poetry install --with dev
-
Update all dependencies:
poetry update
-
Update single dependency, e.g.:
poetry update omnipy
-
If a dependency is not updated to the latest version available on Pypi, you might need to clear the pip cache of poetry:
poetry cache clear pypi --all
For mypy support in PyCharm
- In PyCharm, install "Mypy" plugin (not "Mypy (Official)")
which mypy
to get path to mypy binary- In the PyCharm settings for the mypy plugin:
- Select the mypy binary
- Select
pyproject.toml
as the mypy config file
For automatic formatting and linting
I have added my typical setup for automatic formatting and linting. The main alternative is to use black, which is easier to set up, but it does not have as many options. I am not fully happy with my config, but I at least like it better than black.
- In PyCharm -> File Watchers:
- Click arrow down icon
- Select
watchers.xml
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
File details
Details for the file omnipy_examples-0.6.5.tar.gz
.
File metadata
- Download URL: omnipy_examples-0.6.5.tar.gz
- Upload date:
- Size: 24.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.1 CPython/3.10.8 Darwin/21.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 29e8c530c1f13e8aa51bea370ba875a9ddecdab0adf7cccb2b5e49f6c76cf011 |
|
MD5 | d598f87238f77f8d21191183d6d2288f |
|
BLAKE2b-256 | 011d4fc83554e2545530392048488529e650db6f9813998204efa27cad541580 |
File details
Details for the file omnipy_examples-0.6.5-py3-none-any.whl
.
File metadata
- Download URL: omnipy_examples-0.6.5-py3-none-any.whl
- Upload date:
- Size: 50.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.1 CPython/3.10.8 Darwin/21.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 04f4f2f96c7835a7af55e2285c9d2357c8d2129560c77181a452c194bbc40ebf |
|
MD5 | 1fb9556870456154ad862ee912560907 |
|
BLAKE2b-256 | 8efa3ce28ba6df8f3cdd5bb36fb63802c191514dfa724569eebeaa0efdc1d3a3 |