Skip to main content

Access YAML data in the CLI.

Project description

yaml_pipe

CLI utility for extracting YAML or JSON data. GitHub Repo

Overview

You can use YAML_Pipe as a CLI utility to access and/or search for the key of specific data nodes in a YAML or JSON file. This may help with data processing by not requiring you to, first, manually open and literally read the data file, then then write code in your program to access certain keys to extract the data, and then run your program. YAML_Pipe let's you grab the data, and then pipe it as input to another CLI tool or write it to a new file. It does not modify the original file.

Features

gif demonstrating autocomplete

Usage:

$ yaml_pipe [-h/--help] [-q/--quiet]
<file> <enumerate, yaml, or json> <keys...>
[--search <key>] [--type <int, float, bool, bin, null, or timestamp>]

'yaml_pipe' takes three positional arguments, and four options. Provides autocomplete and abbreviation.

  • HELP: [-h/--help] Usual help option.
  • QUIET: [-q/--quiet] Option to turn off success messages printed to stderr.
  • FILE: [file] Must include path to data file to parse as YAML (JSON is a subset of YAML).
  • COMMAND: <enumerate, yaml, or json> Must select one of three commands:
    • ENUMERATE: Print the nodes at the current level. No nesting. Index sequences.
    • YAML: Output YAML data.
    • JSON: Output JSON string.
  • KEYS: <keys ...> Optionally provide keys and/or indices as extra args to access nested nodes. Tab for autocomplete to list keys and indices.
  • SEARCH: [--search <key>] Optionally search for a key. Must match exactly. Default data type is a string.
  • TYPE: [--type <data_type>] Optionally select the data type of search keys that are not strings. Each choice correlates with a YAML data tag. Is an option for the search option.

NOTE: To ensure autocomplete with argcomplete works as intended, follow the order of arguments found here: $ yaml_pipe -q file command keys... --search key --type data_type

Download/Install

From source:

  1. Clone the repo:
$ git clone https://github.com/skovranek/yaml_pipe
  1. Change directories to the new 'yaml_pipe directory/', then run:
$ python3 -m pip install -e .
$ eval "$(register-python-argcomplete3 yaml_pipe)"

From PyPI:

$ pip install pipeyaml

NOTE: YAML_Pipe is published on PyPI as 'pipeyaml', not 'yaml_pipe' or 'yamlpipe'.

Implement Library

There are a few different functions from this project you may want to import.

access_keys(node: Any, keys: List[str]) -> Any, bool:

Attempt to access value in a series of nested dicts and lists via list of keys and indices as strings. True/False for exists/not exists.

key_search(node: Any, key: str) -> Any, List[Any], bool:

Attempt to find dict key in series of nested dicts and lists. Returned list is path of keys or indices to access value. True/False for found/not found.

print_keys(node: Any):

Prints the first layer of nodes. Keys are listed. Sequences are indexed. Nested values are printed inline flow style.

View the main function of Yaml_Pip for an example of how these functions are used.

Dependencies

The main dependencies of YAML_Pipe are ruamel.yaml to parse YAML and JSON, argparse to parse CLI args, and argcomplete to autocomplete arguments and options.

View the requirements.txt file for the entire list of dependencies.

Testing

Manually tested with a zsh shell in the macOS terminal.

Contact

Questions, issues or suggestions: mattjskov at gmail.com

Contribute

Anyone is welcome to submit pull requests to the main branch.

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

pipeyaml-0.1.1.tar.gz (15.6 kB view details)

Uploaded Source

File details

Details for the file pipeyaml-0.1.1.tar.gz.

File metadata

  • Download URL: pipeyaml-0.1.1.tar.gz
  • Upload date:
  • Size: 15.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.0

File hashes

Hashes for pipeyaml-0.1.1.tar.gz
Algorithm Hash digest
SHA256 dd9b24ba6688e8341d018dd85f35ad9a63a239cc88c003d1aa955d55dc25acbd
MD5 676c996e0f4787a089fff0db2a6eb032
BLAKE2b-256 625519f7b590aeeb7bf7d2a3d68e2ae856f01f57e2a7cbe67181595eed8b8952

See more details on using hashes here.

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