Skip to main content

Python library and CLI app that translates arbitrarily-nested JSON into CSV

Project description

json-tabulate

Python library and CLI app that translates arbitrarily-nested JSON into CSV

Usage

Python library

pip install json-tabulate
>>> from json_tabulate.core import translate_json
>>> translate_json(r'{"name": "Ken", "age": 26}')
'$.age,$.name\n26,Ken\n'

CLI app

Here's the usage string displayed by the CLI app:

json-tabulate --help
 Usage: json-tabulate [OPTIONS] [JSON_STRING]

 Translate JSON into CSV.

 Usage examples:

  • json-tabulate '{"name": "Ken", "age": 26}' (specify JSON via argument)
  • echo '{"name": "Ken", "age": 26}' | json-tabulate (specify JSON via STDIN)
  • cat input.json | json-tabulate > output.csv (write CSV to file)

╭─ Arguments ──────────────────────────────────────────────────────────────────╮
│   json_string      [JSON_STRING]  JSON string to translate. If not provided, │
│                                   program will read from STDIN.              │
╰──────────────────────────────────────────────────────────────────────────────╯
╭─ Options ────────────────────────────────────────────────────────────────────╮
│ --version          Show version number and exit.                             │
│ --help             Show this message and exit.                               │
╰──────────────────────────────────────────────────────────────────────────────╯

Development

Using VS Code? The file, .vscode/tasks.json, contains VS Code task definitions for several of the commands shown below. You can invoke those tasks via the command palette, or—if you have the Task Runner extension installed—via the "Task Runner" panel.

Setup Python virtual environment

Here's how you can create a Python virtual environment and install the Python dependencies within it:

uv sync

Lint Python source code

uv run ruff check --fix

# Other option: Do a dry run.
uv run ruff check

Format Python source code

uv run ruff format

# Other option: Do a dry run.
uv run ruff format --diff

Check data types

uv run mypy

The default configuration is defined in pyproject.toml.

Run tests

uv run pytest

# Other option: Run tests and measure code coverage.
uv run pytest --cov

The default configuration is defined in pyproject.toml.

Build distributable package

uv build

The build artifacts will be in the dist/ directory.

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

json_tabulate-0.1.0.tar.gz (34.0 kB view details)

Uploaded Source

Built Distribution

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

json_tabulate-0.1.0-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

Details for the file json_tabulate-0.1.0.tar.gz.

File metadata

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

File hashes

Hashes for json_tabulate-0.1.0.tar.gz
Algorithm Hash digest
SHA256 8733a02846b32f7e79c235b364d2959bb1006d8b69203b83326d888f752e237e
MD5 c7675d86a5800dcb140808c27d5b0d9c
BLAKE2b-256 8c0f4a6e32faadd7fadbb6ea9067a64286bc4446acf771e9b37732dfc201a881

See more details on using hashes here.

Provenance

The following attestation bundles were made for json_tabulate-0.1.0.tar.gz:

Publisher: build-and-publish-package.yml on eecavanna/json-tabulate

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

File details

Details for the file json_tabulate-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: json_tabulate-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 7.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for json_tabulate-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 81795a5a99caf23989cd46785fc842e86cfcd9d263ebd87f70ec90d07e0493c9
MD5 dcedc2927384df85c4aff671ef711253
BLAKE2b-256 f40ed4583072945ace633eb542e84b93393e8718112995508dca8335bab3865e

See more details on using hashes here.

Provenance

The following attestation bundles were made for json_tabulate-0.1.0-py3-none-any.whl:

Publisher: build-and-publish-package.yml on eecavanna/json-tabulate

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