Skip to main content

PYthon Command Line Interface FramEwoRk — decorator-driven CLI framework built on click-extra and rich-click

Project description

pyclifer logo

pyclifer

PyPI codecov

PYthon Command Line Interface FramEwoRk — a decorator-driven CLI framework built on click-extra and rich-click.

pyclifer provides four decorators (@app_group, @group, @command, @option) that give your CLI applications automatic configuration management, environment variable binding, Rich-enhanced logging, global option propagation, and standardized output formatting — with zero boilerplate.

Installation

pip install pyclifer

Requires Python 3.10+.

Development

Requires Task.

task install       # install dev + docs dependencies
pre-commit install # activate git hooks (ruff check + format on every commit)
task check         # lint + test
task test          # run test suite
task tox           # run tests across Python 3.10–3.13
task release:patch # bump patch version, commit, tag and push
task release:minor
task release:major

Run task --list to see all available tasks.

Quick Start

"""CLI application using pyclifer."""
from pyclifer import app_group, command, option, Response


@app_group(handle_response=True)
def main():
    """My CLI application."""
    pass


@main.command()
@option("--name", "-n", default="World", help="Your name")
def hello(name: str) -> Response:
    """Say hello."""
    return Response(success=True, message=f"Hello {name}!")


if __name__ == "__main__":
    main()
$ python app.py --help
 Usage: app.py [OPTIONS] COMMAND [ARGS]...

 My CLI application.

╭─ Options ────────────────────────────────────────────────────────────────────╮
│     --version                                    Show the version and exit.  │
│     --log-file       FILE                        Path to the log file (with  │
│                                                  daily automatic rotation).  │
│                                                  [env var: MYAPP_LOG_FILE]   │
│ -v  --verbosity      LEVEL                       Either TRACE, DEBUG, INFO,  │
│                                                  WARNING, ERROR, CRITICAL.   │
│                                                  [env var: MYAPP_VERBOSITY]  │
│                                                  [default: WARNING]          │
│ -C  --config         CONFIG_PATH                 Configuration file          │
│                                                  location. Supports glob     │
│                                                  patterns and remote URLs.   │
│                                                  [env var: MYAPP_CONFIG]     │
│                                                  [default:                   │
│                                                  /etc/myapp/*.{toml,yaml,    │
│                                                  yml,json,ini,xml},          │
│                                                  ~/.config/myapp/*.{toml,    │
│                                                  yaml,yml,json,ini,xml}]     │
│ -o  --output-format  [json|yaml|table|rich|raw]  Specify the output format   │
│                                                  for the command. [env var:  │
│                                                  MYAPP_OUTPUT_FORMAT]        │
│                                                  [default: table]            │
│ -h  --help                                       Show this message and exit. │
╰──────────────────────────────────────────────────────────────────────────────╯
╭─ Commands ───────────────────────────────────────────────────────────────────╮
│ hello                       Say hello.                                       │
╰──────────────────────────────────────────────────────────────────────────────╯

$ python app.py hello --name Alice
Hello Alice!

$ python app.py hello --help
 Usage: app.py hello [OPTIONS]

 Say hello.

╭─ Options ────────────────────────────────────────────────────────────────────╮
│ -n  --name           TEXT                        Your name [env var:         │
│                                                  MYAPP_HELLO_NAME] [default: │
│                                                  World]                      │
│ -v  --verbosity      LEVEL                       Either TRACE, DEBUG, INFO,  │
│                                                  WARNING, ERROR, CRITICAL.   │
│                                                  [env var:                   │
│                                                  MYAPP_HELLO_VERBOSITY]      │
│                                                  [default: WARNING]          │
│ -o  --output-format  [json|yaml|table|rich|raw]  Specify the output format   │
│                                                  for the command. [env var:  │
│                                                  MYAPP_HELLO_OUTPUT_FORMAT]  │
│                                                  [default: table]            │
│ -h  --help                                       Show this message and exit. │
╰──────────────────────────────────────────────────────────────────────────────╯

Features

  • Decorator-driven — four decorators (@app_group, @group, @command, @option) cover the full CLI surface
  • Autoconfiguration — TOML/YAML/JSON/XML config files with Linux path conventions (/etc/<app>/, ~/.config/<app>/)
  • Environment variables — automatic prefix-based binding for every option
  • Rich logging — colored output, custom TRACE level, secret masking, rotating log files
  • Structured outputResponse + OperationResult with JSON/YAML/Table/Rich/Raw formatters via --output-format
  • Renderer system — declarative BaseRenderer controls all output formats from a single class; streaming generators drive a Live Rich display via rich_on_item hooks
  • Service layerBaseInterface.respond() auto-detects list vs generator, picks the right renderer, and builds the Response — commands stay thin
  • Global options — options marked is_global=True propagate automatically to all subcommands
  • Pagination — built-in PaginatedResponse with page/limit/total in JSON and YAML output
  • Project scaffoldingpyclifer project init / add app / add command / add integration generates a ready-to-use project structure

Documentation

Full documentation at bahamut45.github.io/pyclifer.

License

MIT — see LICENSE.

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

pyclifer-0.4.2.tar.gz (447.4 kB view details)

Uploaded Source

Built Distribution

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

pyclifer-0.4.2-py3-none-any.whl (91.0 kB view details)

Uploaded Python 3

File details

Details for the file pyclifer-0.4.2.tar.gz.

File metadata

  • Download URL: pyclifer-0.4.2.tar.gz
  • Upload date:
  • Size: 447.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pyclifer-0.4.2.tar.gz
Algorithm Hash digest
SHA256 8b2f32cde652ae53b8ddaee7319e4b467ef42c2714408c9f0c9bf7993a3cf883
MD5 b11072a0760e9b771aa2fb7914c78530
BLAKE2b-256 8a4e05683a8645aae89e7fe57b6859f58ea5a3fd67ab97f8a4ac625424958bad

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyclifer-0.4.2.tar.gz:

Publisher: release.yml on bahamut45/pyclifer

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

File details

Details for the file pyclifer-0.4.2-py3-none-any.whl.

File metadata

  • Download URL: pyclifer-0.4.2-py3-none-any.whl
  • Upload date:
  • Size: 91.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pyclifer-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 8f3077ea7c3cbd56b96572d5f346dbef9854f7a006f3f975749a44a25ad8fb89
MD5 bc3ed70f69be65e9dbfe90c49246f716
BLAKE2b-256 bbafa8974619fdd285279b3db58056a9c41a08d2339877e35d6d09e2e97f2d9e

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyclifer-0.4.2-py3-none-any.whl:

Publisher: release.yml on bahamut45/pyclifer

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