Skip to main content

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

Project description

Frictionless Framework

Travis Coveralls PyPi Github Discord

Frictionless is a framework to describe, extract, validate, and transform tabular data. 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 Data Specifications.

[Important Notice] We have renamed goodtables to frictionless since version 3. The framework got various improvements and was extended to be a complete data solution. The change in not breaking for the existing software so no actions are required. Please read the Migration Guide from goodtables to Frictionless Framework.

  • we continue to bug-fix goodtables@2.x in this branch as well as it's available on PyPi as it was before
  • please note that frictionless@3.x version's API, we're working on at the moment, is not stable
  • we will release frictionless@4.x by the end of 2020 to be the first SemVer/stable version

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 protocols 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

General

Specific

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-3.34.0.tar.gz (155.2 kB view details)

Uploaded Source

Built Distribution

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

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

Uploaded Python 2Python 3

File details

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

File metadata

  • Download URL: frictionless-3.34.0.tar.gz
  • Upload date:
  • Size: 155.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.53.0 CPython/3.8.0

File hashes

Hashes for frictionless-3.34.0.tar.gz
Algorithm Hash digest
SHA256 117c266b90f9279d7bcb05197202946b3aaea600ac71a9af88ef30c21dc51b3b
MD5 653df8128ae1f87655e0b5666c89f8b1
BLAKE2b-256 e23e435e0584047c5fde47b5156ea974147ada5321762878c56c8d9e2be7cbb6

See more details on using hashes here.

File details

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

File metadata

  • Download URL: frictionless-3.34.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.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.53.0 CPython/3.8.0

File hashes

Hashes for frictionless-3.34.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 a50bff4f013466d9d784cea0dda7349a642a7e650a5e1df644d6264fc528b2d8
MD5 6b746ce46859f7af8b9f91607b0579a7
BLAKE2b-256 e06c825fb0567b39e856c4a76164ec1ecb4f3daf78ea7bfb9dfc555461ca5e87

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