rich-color-ext extends the great rich library to be able to parse 3-digit hex colors (ie. #09F) and CSS color names (ie. rebeccapurple).
Latest release:
v0.1.9(2025-11-19). See the changelog for the full list of updates and run the command below to confirm which version is installed locally.
python -c "import rich_color_ext; print(rich_color_ext.__version__)"uv (recommended)
# via uv directly
uv add rich-color-extor
# or via pip through uv
uv pip add rich-color-extpip install rich-color-extTo make use of rich-color-ext all you need to do is import and install it at the start of your program:
from rich_color_ext import install
from rich.console import Console
install() # Patch Rich's Color.parse method
console = Console(width=64)
console.print(
Panel(
"This is the [b #00ff99]rich_color_ext[/b #00ff99] \
example for printing CSS named colors ([bold rebeccapurple]\
rebeccapurple[/bold rebeccapurple]), 3-digit hex \
colors ([bold #f0f]#f0f[/bold #f0f]), and [b #99ff00]\
rich.color_triplet.ColorTriplet[/b #99ff00] & [b #00ff00]\
rich.color.Color[/b #00ff00] instances.",
padding=(1,2)
),
justify="center"
)This package uses loguru for internal, developer-focused logging. By default the
logger is disabled so importing the package is quiet during normal usage. If you
need to enable internal debug output for troubleshooting, you can enable the
logger at runtime. For example:
from rich_color_ext import log
# Enable internal logging emitted by rich-color-ext (useful for debugging)
log.enable("rich_color_ext")
# Revert to disabled state
log.disable("rich_color_ext")Note: loguru is used only for internal diagnostics and is not required at
runtime for the library's primary functionality; it is disabled by default to
avoid noisy output.
As of recent releases the CSS colour map is embedded in the Python package and a separate colors.json file is not required for normal usage. The library and CLI prefer the package-level get_css_map() function, so PyInstaller bundles typically do not need any extra data files.
If you are building or packaging an older distribution that expects a
standalone colors.json file, or you intentionally rely on shipping the JSON resource, include it in the bundle using the legacy approaches below.
-
Pass the file with the command-line option
--add-data:-
macOS / Linux (colon separator):
pyinstaller --onefile --add-data "static/json/colors.json:rich_color_ext" your_entry_script.py -
Windows (semicolon separator):
pyinstaller --onefile --add-data "static\\json\\colors.json;rich_color_ext" your_entry_script.py
-
-
Add the file to the spec file's
Analysis.dataslist. Example snippet to paste into your.specfile:a = Analysis( ['your_entry_script.py'], pathex=[], binaries=[], datas=[('static/json/colors.json', 'rich_color_ext')], hiddenimports=[], hookspath=[], runtime_hooks=[], excludes=[], win_no_prefer_redirects=False, win_private_assemblies=False, cipher=None, )
A small helper script is provided to build with PyInstaller and automatically choose the correct data separator for your platform. By default it builds the example src/rich_color_ext/cli.py entry script but you can pass any entry script as the first argument.
Usage:
./scripts/pyinstaller_build.sh [path/to/your_entry_script.py] # src/rich_color_ext/cli.py