A light library to preprocess data with polars
Project description
grizz
Overview
grizz
is a light library to ingest and transform data
in polars DataFrame.
grizz
uses an object-oriented strategy, where ingestors and transformers are building blocks that
can be combined together.
grizz
can be extend to add custom DataFrame ingestors and transformers.
For example, the following example shows how to change the casting of some columns.
>>> import polars as pl
>>> from grizz.transformer import Cast
>>> transformer = Cast(columns=["col1", "col3"], dtype=pl.Int32)
>>> frame = pl.DataFrame(
... {
... "col1": [1, 2, 3, 4, 5],
... "col2": ["1", "2", "3", "4", "5"],
... "col3": ["1", "2", "3", "4", "5"],
... "col4": ["a", "b", "c", "d", "e"],
... }
... )
>>> out = transformer.transform(frame)
>>> out
shape: (5, 4)
┌──────┬──────┬──────┬──────┐
│ col1 ┆ col2 ┆ col3 ┆ col4 │
│ --- ┆ --- ┆ --- ┆ --- │
│ i32 ┆ str ┆ i32 ┆ str │
╞══════╪══════╪══════╪══════╡
│ 1 ┆ 1 ┆ 1 ┆ a │
│ 2 ┆ 2 ┆ 2 ┆ b │
│ 3 ┆ 3 ┆ 3 ┆ c │
│ 4 ┆ 4 ┆ 4 ┆ d │
│ 5 ┆ 5 ┆ 5 ┆ e │
└──────┴──────┴──────┴──────┘
Documentation
- latest (stable): documentation from the latest stable release.
- main (unstable): documentation associated to the main branch of the repo. This documentation may contain a lot of work-in-progress/outdated/missing parts.
Installation
We highly recommend installing
a virtual environment.
grizz
can be installed from pip using the following command:
pip install grizz
To make the package as slim as possible, only the minimal packages required to use grizz
are
installed.
To include all the dependencies, you can use the following command:
pip install grizz[all]
Please check the get started page to see how to
install only some specific dependencies or other alternatives to install the library.
The following is the corresponding grizz
versions and their dependencies.
grizz |
coola |
iden |
objectory |
polars |
python |
---|---|---|---|---|---|
main |
>=0.7,<1.0 |
>=0.0.4,<1.0 |
>=0.1,<1.0 |
>=1.0,<2.0 |
>=3.9,<3.13 |
0.0.5 |
>=0.7,<1.0 |
>=0.0.4,<1.0 |
>=0.1,<1.0 |
>=1.0,<2.0 |
>=3.9,<3.13 |
0.0.4 |
>=0.7,<1.0 |
>=0.0.4,<1.0 |
>=0.1,<1.0 |
>=1.0,<2.0 |
>=3.9,<3.13 |
Optional dependencies
grizz |
clickhouse-connect * |
pyarrow * |
tqdm * |
---|---|---|---|
main |
>=0.7,<1.0 |
>=10.0,<18.0 |
>=4.65,<5.0 |
0.0.5 |
>=0.7,<1.0 |
>=10.0,<18.0 |
>=4.65,<5.0 |
0.0.4 |
>=0.7,<1.0 |
>=10.0,<17.0 |
>=4.65,<5.0 |
* indicates an optional dependency
Contributing
Please check the instructions in CONTRIBUTING.md.
Suggestions and Communication
Everyone is welcome to contribute to the community. If you have any questions or suggestions, you can submit Github Issues. We will reply to you as soon as possible. Thank you very much.
API stability
:warning: While grizz
is in development stage, no API is guaranteed to be stable from one
release to the next.
In fact, it is very likely that the API will change multiple times before a stable 1.0.0 release.
In practice, this means that upgrading grizz
to a new version will possibly break any code that
was using the old version of grizz
.
License
grizz
is licensed under BSD 3-Clause "New" or "Revised" license available in LICENSE
file.
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 grizz-0.0.5.tar.gz
.
File metadata
- Download URL: grizz-0.0.5.tar.gz
- Upload date:
- Size: 27.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/6.5.0-1023-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 50956dc67d3c453a0bcb8f3eeaae9d980df0eae81fdefb0dba16ff0ea5c90cb0 |
|
MD5 | 46b2489561e9e64100b6ca3dfbf29b04 |
|
BLAKE2b-256 | f3aa9aba148308692d97ad1574c1ef1feb63d16ae7fc8ab65ecdb3b74c1b52ee |
File details
Details for the file grizz-0.0.5-py3-none-any.whl
.
File metadata
- Download URL: grizz-0.0.5-py3-none-any.whl
- Upload date:
- Size: 44.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/6.5.0-1023-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9c79901b2d52f4fe8f2fc90603ffe14fdb3a10a7608ef568d8519beabdb6c6c8 |
|
MD5 | eea9824afc191502e32c57dff6bc9dc3 |
|
BLAKE2b-256 | c61460a18ce1e995c7209a6ec9520c03ab7b92d62e9f0cf8f1a8ff2948cb80da |