What is Click Extra?¶
It should be easy to write a good CLI in Python. Click makes it so. But there is still hundrends of tweaks to implement by yourself to have a user-friendly CLI.
Click Extra is a ready-to-use wrapper around Click to make your CLI look good and behave well. It is a drop-in replacement with good defaults that saves lots of boilerplate code and frustration by making all parts working together.
It also comes with workarounds and patches that have not reached upstream yet (or are unlikely to).
Who is this for?¶
Anyone building a CLI who doesn’t have time to assemble the pieces from scratch:
You use Click and want professional defaults without the boilerplate.
You’re a security researcher turning a proof-of-concept into a presentable tool to hand off, demo, or attach to an advisory.
You’re a DevOps engineer or sysadmin whose one-off script grew into a team tool and needs
--help,--verbose,--config, and colored output.
Click Extra’s defaults-first design means one decorator gets you there. See the 30-second quick start.
Demo¶
You can try Click Extra right now in your terminal, without installing any dependency or virtual env thanks to uvx:
$ uvx click-extra
This is a great way to play with Click Extra and check that it runs fine on your system, and renders properly in your terminal.
Example¶
It transforms this vanilla click CLI:

Into this:

To undestrand how we ended up with the result above, go read the tutorial.
Features¶
Configuration¶
Multi-format configuration file loader for:
TOMLYAMLJSON,JSON5,JSONCandHJSONINI, with extended interpolation, multi-level sections and non-native types (list,set, …)XML
Automatic
pyproject.tomlintegration: the CLI reads its[tool.<cli>]section from the user’s project file, including a CWD-aware walk that skips unrelatedpyproject.tomlfilesInference of the configuration file structure from your CLI’s options, with optional dataclass schema typing so values arrive parsed and validated
Remote loading of configuration from URLs
Optional strict validation of configuration with
--validate-configExtension hook (
ConfigValidator) for user-defined sub-trees whose keys are data rather than CLI flags (per-plugin overrides, matrix axes, user-defined IDs), with rootedValidationErrorreportingRespect the default application path on each platform (XDG spec. on Linux)
Glob search patterns for configuration files
A
--no-configoption to disable configuration file loadingRespect of
CLI>Configuration>Environment>Defaultsprecedence
Help screens and theming¶
Colorized help screens: options, choices, metavars, arguments, defaults, ranges, required labels, environment variables, subcommands and aliases all get distinct styles. Option names referenced in descriptions and docstrings are highlighted automatically
Theme system with six built-in palettes (
dark,light,dracula,monokai,nord,solarized_dark)User-defined themes and partial overrides loaded from the CLI’s
--configfile ([tool.<cli>.themes.<name>]), scoped per invocation so concurrent runs don’t bleed into each other--themeflag on every command, with case-insensitive validation against the live registry-h/--helpoption names (see rant on other inconsistencies)Built-in
helpsubcommand with a--searchmode for groups
Standard options on every CLI¶
Colored
--versionwith template variables for git metadata (branch, hash, date, tag) and pre-baking for compiled binaries (Nuitka, PyInstaller)Colored
--verbosityLEVEL and logs, plus-v/--verboserepetition for incremental bumping--show-paramsto debug parameter defaults, values, environment variables and provenance--time/--no-timeto measure command execution duration--table-formatto switch between 40+ table-rendering styles (usesprint_table()andserialize_data())--jobsfor parallel-execution worker counts--telemetry/--no-telemetryflag to opt-in/out of tracking code--color/--no-coloroption flag, with recognition ofNO_COLOR(no-color.org),FORCE_COLOR,CLICOLOR, andLLMenvironment variablesRecognition of
DO_NOT_TRACKfrom consoledonottrack.com for telemetryGlobal
show_envvaroption to display all environment variables in help screensGlobal
show_choicesto activate selection of choices on user input promptsAuto-generation and normalization of environment variables for all options
Types and parameters¶
EnumChoice—click.Choicesubclass with properEnumrendering, case-insensitive matching, alias support, and pluggable choice sourcesClick parameter introspection and a shared parameter structure used by both
--show-paramsand the config loader
CLI wrapper¶
CLI wrapper (
click-extra wrap) applies help colorization, themes, and config loading to any Click CLI without modifying its source codeshow-paramssubcommand to introspect any external Click CLI’s parametersUser-defined themes via
--configwork transparently through the wrapper, so users can theme third-party CLIs from their ownpyproject.toml
Performance and structure¶
Lazy-loading of subcommands from module paths to speed up CLI startup time
Composition with third-party Click CLIs (
wrap_other_commands)
Documentation tooling¶
click:sourceandclick:runSphinx directives in MyST Markdown and reStructuredText to document CLI source code and their executionpython:source,python:run,python:render,python:render-myst,python:render-rst— the same machinery for arbitrary Python, with arender*family that parses the captured output as live document content (replaces thedocs_update.py+ marker-region pattern)Inline testing of CLI examples in documentation: every
click:runblock runs at build time and assertions fail the buildRender GitHub alerts into MyST admonitions in both Sphinx and MkDocs
ANSI-capable Pygments lexers for shell session and console output, with 24-bit true-color rendering on by default
AnsiHtmlFormatterfor HTML output of ANSI-colored textMkDocs plugin for ANSI color rendering in code blocks
Testing¶
ExtraCliRunner—click.testing.CliRunnersubclass that capturesstdoutandstderrseparately and preserves ANSI codes for assertion against colored outputpytest fixtures (
invoke,extra_runner,create_config) and ready-made regex helpers (default_options_uncolored_help,default_debug_*) for click-extra-aware test suites
Upstream¶
Fixes 100+ bugs and addresses missing features across Click, Cloup, Pygments, tabulate, MyST-Parser, Furo, and unmaintained
click-contribpackagesDrop-in replacement for Click and Cloup: every
from click_extra import …and@click_extra.commandworks as a transparent superset. Cloup provides option groups, constraints, subcommand sections, aliases, andDid you mean <subcommand>?suggestions; click-extra adds everything above on top.
Used in¶
Check these projects to get real-life examples of click-extra usage:
Meta Package Manager - A unifying CLI for multiple package managers.
Mail Deduplicate - A CLI to deduplicate similar emails.
fireproxng - A rewrite of the fireprox tool.
agent-catalog - Couchbase agent catalog.
badger-proxy - An mDNS-based reverse proxy for naming services on a local network.
Feel free to send a PR to add your project in this list if you are relying on Click Extra in any way.