Skip to main content

Another data transformation language

Project description

adtl – another data transformation language

Python 3.9+

tests codecov Code style: black

adtl is a data transformation language (DTL) used by some applications in Global.health, notably for the ISARIC clinical data pipeline at globaldothealth/isaric and the InsightBoard project dashboard at globaldothealth/InsightBoard

Documentation: ReadTheDocs

Installation

You can install this package using either pipx or pip. Installing via pipx offers advantages if you want to just use the adtl tool standalone from the command line, as it isolates the Python package dependencies in a virtual environment. On the other hand, pip installs packages to the global environment which is generally not recommended as it can interfere with other packages on your system.

  • Installation via pipx:

    pipx install adtl
    
  • Installation via pip:

    python3 -m pip install adtl
    

If you are writing code which depends on adtl (instead of using the command-line program), then it is best to add a dependency on adtl to your Python build tool of choice.

To use the development version, replace adtl with the full GitHub URL:

pip install git+https://github.com/globaldothealth/adtl

Rationale

Most existing data transformation languages are usually in a XML dialect, though there are recent variations in other file formats. In addition, many DTLs use a custom domain specific language. The primary utility of this DTL is to provide a easy to use library in Python for basic data transformations, which are specified in a JSON file. It is not meant to be a comprehensive, and adtl can be used as a step within a larger data processing pipeline.

Usage

adtl can be used from the command line or as a Python library

As a CLI:

adtl specification-file input-file

Here specification-file is the parser specification (as TOML or JSON) and input-file is the data file (not the data dictionary) that adtl will transform using the instructions in the specification.

Python library:

import adtl

parser = adtl.Parser(specification)
print(parser.tables) # list of tables created

for row in parser.parse().read_table(table):
    print(row)

If adtl is not in your PATH, this may give an error. Either add the location where the adtl script is installed to your PATH, or try running adtl as a module

python3 -m adtl specification-file input-file

Running adtl will create output files with the name of the parser, suffixed with table names in the current working directory.

Development

Install pre-commit and setup pre-commit hooks (pre-commit install) which will do linting checks before commit.

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

adtl-0.6.1.tar.gz (29.7 kB view details)

Uploaded Source

Built Distribution

adtl-0.6.1-py3-none-any.whl (18.9 kB view details)

Uploaded Python 3

File details

Details for the file adtl-0.6.1.tar.gz.

File metadata

  • Download URL: adtl-0.6.1.tar.gz
  • Upload date:
  • Size: 29.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for adtl-0.6.1.tar.gz
Algorithm Hash digest
SHA256 393a6be47e1c8dd08fde1efcefd55f6c21d6f81edaf14b7bc376440f7bdf5e74
MD5 c00e872d6a994555def6514303b2fb8f
BLAKE2b-256 cf13dcb560886c89531a0b374842663f143fd4225c6cbb156d25dcd174bd7db7

See more details on using hashes here.

Provenance

The following attestation bundles were made for adtl-0.6.1.tar.gz:

Publisher: publish.yml on globaldothealth/adtl

Attestations:

File details

Details for the file adtl-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: adtl-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 18.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for adtl-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 bc3d6eda0dc0074cbc418a5093826e0d076962572c46b22040fa4d0e202ea6d3
MD5 1762424b9e63319246c1d0c85781bf64
BLAKE2b-256 8995eef56b0581f63e4cedcb84a0265bae7fa88b5ae2541b41d60f98074a4eb4

See more details on using hashes here.

Provenance

The following attestation bundles were made for adtl-0.6.1-py3-none-any.whl:

Publisher: publish.yml on globaldothealth/adtl

Attestations:

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