Skip to main content

Cat structured data , in style

Project description

dotcat: Cat Structured Data, in Style

Dealing with structured data in shell scripts is all but impossible. dotcat gives you the ability to fetch structured data as easily as using cat it.

# Access data by attribute path
dotcat data.json person.name.first
# John
dotcat data.json person.name.last
# Doe

# Controle your output format
dotcat data.json person.name --output=yaml
# name:
#   first: John
#   last: Doe
dotcat data.json person.name --output=json
# {"first": "John", "last": "Doe"}

# List access
dotcat data.json person.friends@0
# {"name":{"first": "Alice", "last": "Smith"}, "age": 25} -> item access
dotcat data.json person.friends@2:4
# [{"name":{"first": "Alice", "last": "Smith"}, "age": 25}, {"name":{"first": "Bob", "last": "Johnson"}, "age": 30}]  -> slice access
dotcat data.json person.friends@4:-1
# ... from 5th to last item

The good times are here

Easily read values from JSON, YAML, TOML, and INI files without complex scripting or manual parsing.

Access deeply nested values using intuitive dot-separated paths (e.g., person.first.name) while controlling the output format with --output flag.

Dotcat is a good unix citizen with well structured exit codes so it can take part of your command pipeline like cat or grep would.

Includes ZSH autocompletion for both file paths and dotted paths, making it even easier to navigate complex data structures.

Installation

If you have a global pip install, this will install dotcat globally:

pip install dotcat

ZSH Completion

Dotcat comes with ZSH completion support that is automatically installed when you install the package with pip. The installation script will:

  1. Look for appropriate ZSH completion directories
  2. Install the completion files if possible
  3. Notify you of the installation location

If the automatic installation fails, you can manually install the completions:

# Copy the completion script to your ZSH completions directory
mkdir -p ~/.zsh/completions
cp /path/to/installed/package/zsh/_dotcat ~/.zsh/completions/

# Or run the installation script directly
dotcat-install-completions

See the ZSH completion README for detailed instructions.

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

dotcat-0.9.6.tar.gz (21.3 kB view details)

Uploaded Source

Built Distribution

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

dotcat-0.9.6-py3-none-any.whl (28.6 kB view details)

Uploaded Python 3

File details

Details for the file dotcat-0.9.6.tar.gz.

File metadata

  • Download URL: dotcat-0.9.6.tar.gz
  • Upload date:
  • Size: 21.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.3

File hashes

Hashes for dotcat-0.9.6.tar.gz
Algorithm Hash digest
SHA256 24a9fcb3286fb9267443ceb3416dd4e64956641662a1154bdb78d23ec030e5b3
MD5 7757d1b2c3cd07e055bde3417510930d
BLAKE2b-256 617a2b5ba10c4b31846f56cebbf7b761da5ec316a124d2c35c3627bc45dbfb75

See more details on using hashes here.

File details

Details for the file dotcat-0.9.6-py3-none-any.whl.

File metadata

  • Download URL: dotcat-0.9.6-py3-none-any.whl
  • Upload date:
  • Size: 28.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.3

File hashes

Hashes for dotcat-0.9.6-py3-none-any.whl
Algorithm Hash digest
SHA256 943dbfb78a89adbddf87bcb5a55172b135f18021572dc3240dc691398c92a20f
MD5 d640c7a27d48a229fde818f8500fbfbf
BLAKE2b-256 c732966cd85077176aea42883bc2660b794a391d4c221d912c760d6ac769da07

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