Skip to main content

A simple and elegant Python library for terminal text coloring.

Project description

colrs 🎨

A radically simple Python library for coloring your terminal output.

License: MIT

colrs takes a different approach to terminal coloring. Instead of wrapping your print statements in special functions, you activate it once, and your standard print and input functions become color-aware.


Philosophy

The core idea is absolute simplicity. No new function names to remember for printing. Just activate the magic and write your code as you normally would, but with added superpowers.

  • Activate: act()
  • Use print and input normally: Add colors with tags or keyword arguments.
  • Deactivate: unact()
  • Show Animations: loading()

This is the core public API, designed for simplicity and power.

Installation

To install the library:

pip install colrs

How to Use

The usage is designed to be as intuitive as possible. You import act and unact, and wrap the code you want to be color-aware.

Basic Example

from colrs import act, unact

# This print is normal
print("This is default terminal text.")

# Activate the color patching
act()

# Now, print() and input() are super-powered!
print("This is a <green>green text</> using inline tags.")
print("This is red.", color="red")
print("This is blue on a yellow background.", color="blue", bg_color="yellow")

name = input("What's your name? ", color="cyan", inp_color="magenta")
print(f"Hello, {name}!")

# It's good practice to deactivate when you're done
unact()

print("And we're back to normal.")

Using print() with act()

Once act() is called, print() can accept two new keyword arguments: color and bg_color.

More powerfully, you can use inline tags for fine-grained control.

act()

# Simple tags
print("<red>This will be red.</red>") # The closing tag is optional

# Nested tags
print("<yellow>This is yellow with <blue>blue text</blue> inside.</yellow>")

# Background colors
print("<white,bg_red> White text on a red background. </>") # </> resets all

unact()

Using input() with act()

The patched input() can color three things separately:

  1. The prompt text (color and bg_color arguments, or tags).
  2. The text the user types (inp_color argument).
act()

# The prompt will be yellow, and the user's typing will be cyan
username = input("Enter username: ", color="yellow", inp_color="cyan")

# You can also use tags in the prompt
password = input("<red>Enter password:</red> ", inp_color="red")

unact()

Why colrs?

If you want a coloring library that "just works" in the background without forcing you to change your coding habits, colrs is for you. It's designed for scripts and applications where you want to enable colors globally with minimal code changes.

License

This project is licensed under the MIT 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

colrs-0.1.8.tar.gz (13.9 kB view details)

Uploaded Source

Built Distribution

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

colrs-0.1.8-py3-none-any.whl (16.4 kB view details)

Uploaded Python 3

File details

Details for the file colrs-0.1.8.tar.gz.

File metadata

  • Download URL: colrs-0.1.8.tar.gz
  • Upload date:
  • Size: 13.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.4

File hashes

Hashes for colrs-0.1.8.tar.gz
Algorithm Hash digest
SHA256 4fb2c3f44e02ef8503e38db52daa75dc9e75984374df021bbcc5b35031cd6af7
MD5 4a6dde36178a28613705f8daebe72eeb
BLAKE2b-256 10e456ec1e96434b78d61ca611c8e7a7e6ac4df94b75eab1d244ec0f1448a435

See more details on using hashes here.

File details

Details for the file colrs-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: colrs-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 16.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.4

File hashes

Hashes for colrs-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 459e9d1594151a8180dc79a3242d11d8ae3fad9049f701f87fe3b27478e6b651
MD5 d5ac8725b96035cedffd48b270cf7877
BLAKE2b-256 708370f0f71d1edb7b9e8ec3d5c9f8a85d98080e626adb1c90ddbb0508a8c2ec

See more details on using hashes here.

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