Skip to main content

Data management framework for Python that provides functionality to describe, extract, validate, and transform tabular data

Project description

Frictionless Framework

Build Coverage Release Citation Codebase Support

Migrating from an older version? Please read **[v5](blog/2022/08-22-frictionless-framework-v5.html)** announcement and migration guide.

Data management framework for Python that provides functionality to describe, extract, validate, and transform tabular data (DEVT Framework). It supports a great deal of data sources and formats, as well as provides popular platforms integrations. The framework is powered by the lightweight yet comprehensive Frictionless Standards.

Purpose

  • Describe your data: You can infer, edit and save metadata of your data tables. It's a first step for ensuring data quality and usability. Frictionless metadata includes general information about your data like textual description, as well as, field types and other tabular data details.
  • Extract your data: You can read your data using a unified tabular interface. Data quality and consistency are guaranteed by a schema. Frictionless supports various file schemes like HTTP, FTP, and S3 and data formats like CSV, XLS, JSON, SQL, and others.
  • Validate your data: You can validate data tables, resources, and datasets. Frictionless generates a unified validation report, as well as supports a lot of options to customize the validation process.
  • Transform your data: You can clean, reshape, and transfer your data tables and datasets. Frictionless provides a pipeline capability and a lower-level interface to work with the data.

Features

  • Open Source (MIT)
  • Powerful Python framework
  • Convenient command-line interface
  • Low memory consumption for data of any size
  • Reasonable performance on big data
  • Support for compressed files
  • Custom checks and formats
  • Fully pluggable architecture
  • The included API server
  • More than 1000+ tests

Example

$ frictionless validate data/invalid.csv
[invalid] data/invalid.csv

  row    field  code              message
-----  -------  ----------------  --------------------------------------------
             3  blank-header      Header in field at position "3" is blank
             4  duplicate-header  Header "name" in field "4" is duplicated
    2        3  missing-cell      Row "2" has a missing cell in field "field3"
    2        4  missing-cell      Row "2" has a missing cell in field "name2"
    3        3  missing-cell      Row "3" has a missing cell in field "field3"
    3        4  missing-cell      Row "3" has a missing cell in field "name2"
    4           blank-row         Row "4" is completely blank
    5        5  extra-cell        Row "5" has an extra value in field  "5"

Documentation

Please visit our documentation portal:

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

frictionless-5.7.1.tar.gz (253.0 kB view details)

Uploaded Source

Built Distribution

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

frictionless-5.7.1-py2.py3-none-any.whl (446.0 kB view details)

Uploaded Python 2Python 3

File details

Details for the file frictionless-5.7.1.tar.gz.

File metadata

  • Download URL: frictionless-5.7.1.tar.gz
  • Upload date:
  • Size: 253.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.2

File hashes

Hashes for frictionless-5.7.1.tar.gz
Algorithm Hash digest
SHA256 cfec3a5f8ab993e5189349fd00229997ff061d41c1391e406bdc6df3dc3ae1fd
MD5 06cbba75c539e8c3e669048452fef827
BLAKE2b-256 ed6db615776bd3ef18d7e033979727b53733b8f4281d1950812a54e9a791ef1f

See more details on using hashes here.

File details

Details for the file frictionless-5.7.1-py2.py3-none-any.whl.

File metadata

  • Download URL: frictionless-5.7.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 446.0 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.2

File hashes

Hashes for frictionless-5.7.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 12f6d524ee407e2600f50fdc3f2c4778fbaec258f80b391cdfbdc51f5e9cce80
MD5 4cb23cbe20cdc155c95bffcb699a5373
BLAKE2b-256 379cb89c9e814a5b030abb4365f856288d9df663e1e76d9494918d28c07afadd

See more details on using hashes here.

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