Skip to main content

No project description provided

Project description

openapi-spec-tools

This is a small set of tools to help provide easy to use, flexible tools for display complex objects for a CLI.

Getting started

The project has been published to PyPi, so you should be able to install it with something like one of the following (depending on how you do Python package management):

% pip install rich-objects
% poetry add rich-objects

The sections below provide a brief description with links to more examples and details.

Background

This module extends the rich module to provide pretty printing of complex data objects. The most common use case is a CLI that displays the json/yaml data that is returned to a CLI client in several different formats.

The easiest way to leverage this library is using the display() function. You can provide a fmt and style to provide different means of displaying the data.

Here are some of the lower level elements:

  • OutputFormat and OutputSyle are enums suitable to use as a CLI argument to support different displays
  • RichTable class is a thin wrapper derived from rich.Table. It contains some default formatting for the tables, since it becomes confusing when tables are nested.
  • Added several functions starting with rich_table_factory() to create a RichTable with appropriate nesting based on the data returned by the data in the object.
  • The console_factory() is the default means for printing the output, but this just sets the rich.Console width.

Examples

In general, this can be used in any enviroment where CLI output is used.

Typer Example

Here's a simple Python example to leverage the new code:

#!/usr/bin/env python3
from typer import Typer
from rich_objects import OutputFormat, display

DATA = [
    {"name": "sna", "prop1": 1, "prop B": None, "blah": "zay"},
    {
        "name": "foo",
        "prop2": 2,
        "prop B": True,
    },
    {
        "name": "bar",
        1: "inverse",
    },
]

app = Typer()

@app.command()
def print_data(
    output_fmt: OutputFormat = OutputFormat.TEXT,
    output_style: OutputStyle = OutputStyle.ALL,
    indent: int = 2,
):
    data = DATA  # TODO: figure out how to get your data here
    display(data, fmt=output_fmt, style=output_style, indent=indent)

if __name__ == "__main__":
    app()

Here's some sample output:

(.venv) > ./example.py
┏━━━━━━┳━━━━━━━━━━━━━━━━┓
┃ Name  Properties     ┃
┡━━━━━━╇━━━━━━━━━━━━━━━━┩
│ sna    prop1   1     │
│        prop B  None  │
│        blah    zay   │
├──────┼────────────────┤
│ foo    prop2   2     │
│        prop B  True  │
├──────┼────────────────┤
│ bar    1  inverse    │
└──────┴────────────────┘
Found 3 items            
(.venv) > ./example.py --output-fmt json
[
  {
    "name": "sna",
    "prop1": 1,
    "prop B": null,
    "blah": "zay"
  },
  {
    "name": "foo",
    "prop2": 2,
    "prop B": true
  },
  {
    "name": "bar",
    "1": "inverse"
  }
]
(.venv) > ./example.py --output-fmt yaml
- blah: zay
  name: sna
  prop B: null
  prop1: 1
- name: foo
  prop B: true
  prop2: 2
- name: bar
  1: inverse

(.venv) > 

Contributing

This project is just getting going... More development instructions will be added later. If you have any suggestions, please email Rick directly (rickwporter@gmail.com).

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

rich_objects-0.1.0.tar.gz (7.6 kB view details)

Uploaded Source

Built Distribution

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

rich_objects-0.1.0-py3-none-any.whl (9.4 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for rich_objects-0.1.0.tar.gz
Algorithm Hash digest
SHA256 8a3552f3d4442d1e864b46f2f2764a037d20c34d66207bf8446a5718b540f7eb
MD5 4a8b4e29d67df6f3f08632e84d6b8f47
BLAKE2b-256 985cc8d1a700369b3db2da5d89b40c347e7b9be2c26a1bdd07d7056bb389ddac

See more details on using hashes here.

Provenance

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

Publisher: pypi_publish.yaml on rickwporter/rich-objects

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

File details

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

File metadata

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

File hashes

Hashes for rich_objects-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d688522fd6238c9e2b9f9ae5ed2566c3dd057ba2399867e56968444c26217cab
MD5 3a716cd9344a63b997c52786d7f3bed7
BLAKE2b-256 774222e59cb98274aecd8d0d6b8b4b0494492bdf7948fd97627deb4d04df13be

See more details on using hashes here.

Provenance

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

Publisher: pypi_publish.yaml on rickwporter/rich-objects

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