Skip to main content

Validate column specifications and constraints for SQL tables and polars data frames.

Project description

pydiverse.colspec

CI

A data validation library that ensures type conformity of columns in SQL tables and polars data frames. It can also validate constraints regarding the data as defined in a so-called column specification provided by the user.

The purpose is to make data pipelines more robust by ensuring that data meets expectations and more readable by adding type hints when working with tables and data frames.

ColSpec is founded on the ideas of dataframely which does exactly the same but with focus on polars data frames. ColSpec delegates to dataframely in the back especially for features like sampling random input data conforming to a given column specification. dataframely uses the term schema as it is also used in the polars community. Since ColSpec also works with SQL databases where the term schema is used for a collection of tables, the term is avoided as much as possible. The term column specification means exactly the same but avoids the confusion.

Merit attribution

ColSpec is the brain child of dataframely. Large parts of the codebase is code duplicated from it. Unfortunately, integrating the SQL native validation into dataframely would have made it a less clean solution for people who just focus on Polars. Thus the decision was made to replicate the same functionality in the pydiverse library collection also with the benefit to enable smoother integration with other pydiverse libraries.

Usage

pydiverse.colspec can either be installed via pypi with pip install pydiverse-colspec or via conda-forge with conda install pydiverse-colspec -c conda-forge. Our recommendation would be to use pixi which is also based on conda-forge:

mkdir my_project
pixi init
pixi add pydiverse-colspec

With pixi, you run python like this:

pixi run python -c 'import pydiverse.colspec'

or this:

pixi run python my_script.py

Project details


Download files

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

Source Distribution

pydiverse_colspec-0.3.1.tar.gz (37.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pydiverse_colspec-0.3.1-py3-none-any.whl (56.3 kB view details)

Uploaded Python 3

File details

Details for the file pydiverse_colspec-0.3.1.tar.gz.

File metadata

  • Download URL: pydiverse_colspec-0.3.1.tar.gz
  • Upload date:
  • Size: 37.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pydiverse_colspec-0.3.1.tar.gz
Algorithm Hash digest
SHA256 c412b42e18d468d6bce555fef79844da3c607b6f068129d7f294b0144a004535
MD5 5a41dfb6f3583322cf62ac114efdb893
BLAKE2b-256 4117d70604e36264ee80742c9896657feec6e79ae5c29875abd22cafd526aa20

See more details on using hashes here.

Provenance

The following attestation bundles were made for pydiverse_colspec-0.3.1.tar.gz:

Publisher: release.yml on pydiverse/pydiverse.colspec

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pydiverse_colspec-0.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for pydiverse_colspec-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 bc864c147f4874862c0c6bb8c158c124d86e6434c95af6add3396dd97fb6962d
MD5 112cbb24d1670314c72439d0f65b8b1e
BLAKE2b-256 89603449834f98d31c52bccd23620b6ac2fe443792ab3df655112578af18180a

See more details on using hashes here.

Provenance

The following attestation bundles were made for pydiverse_colspec-0.3.1-py3-none-any.whl:

Publisher: release.yml on pydiverse/pydiverse.colspec

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page