Skip to main content

Frictionless is a framework to describe, extract, validate, and transform tabular data

Project description

Frictionless Framework

Build Coverage Registry Codebase Support

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

Frictionless@4 is now live! Please read the migration guide.

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

  • 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-4.0.0.tar.gz (151.7 kB view details)

Uploaded Source

Built Distribution

frictionless-4.0.0-py2.py3-none-any.whl (215.4 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

  • Download URL: frictionless-4.0.0.tar.gz
  • Upload date:
  • Size: 151.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.56.2 CPython/3.9.1

File hashes

Hashes for frictionless-4.0.0.tar.gz
Algorithm Hash digest
SHA256 3e1f5c61f147a962ce99781cf5bc8c78cdc486955c71899b9f7dc7394c855bc3
MD5 6e1bb7bfad3202ac652f72c0c7aa0979
BLAKE2b-256 0cc2a0eeb9ddd7ccd0d23766efd727f2ccc6d696a16f951c543b50d577432a14

See more details on using hashes here.

Provenance

File details

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

File metadata

  • Download URL: frictionless-4.0.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 215.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.56.2 CPython/3.9.1

File hashes

Hashes for frictionless-4.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e549ec0ede7c781ff2e6d07da6d36fc6db14127ae3eacd0e550a9bc17d3d26e5
MD5 ea5b8d76d7355549997e9b7f431296a0
BLAKE2b-256 f23bdab2389205e65ac70bf967201f8eb899ae968f5c9e1d56630eb6b62cbe00

See more details on using hashes here.

Provenance

Supported by

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