Skip to main content

ANSI colors for Python

Project description

travisci PyPI Package latest release Supported versions Supported implementations Wheel packaging support Test line coverage

ANSI colors for Python

Add ANSI colors and decorations to your strings.

Example Usage

from __future__ import print_function  # accomodate Python 2
from colors import *

print(color('my string', fg='blue'))
print(color('some text', fg='red', bg='yellow', style='underline'))

The strings returned by color will have embedded ANSI code sequences stipulating text colors and styles. For example, the above code will print the strings:

'\x1b[34mmy string\x1b[0m'
'\x1b[31;43;4msome text\x1b[0m'

You can choose the foreground (text) color with the fg parameter, the background color with bg, and the style with style.

You can choose one of the 8 basic ANSI colors: black, red, green, yellow, blue, magenta, cyan, and white, plus a special default which is display-specific, but usually a rational “no special color” setting.

There are other ways to specify colors. Many devices support an idiosyncratic 256-color scheme developed as an ANSI extension in conjunction with the xterm terminal emulator. Colors (or grays) from this larger palette can be specified via int value.

To see them all:

from __future__ import print_function
from colors import color

for i in range(256):
    print(color('Color #%d' % i, fg=i))

The included show_colors.py program is a much-expanded version of this idea that can be used to explore available color and style combinations on your terminal or output device.

Modern terminals go even further than the xterm 256, often supporting a full 24-bit RGB color scheme. You can provide a full RGB value several ways:

  • with a 3-element tuple or list of int, each valued 0 to 255 (e.g. (255, 218, 185)),

  • a string containing a CSS-compatible color name (e.g. 'peachpuff'),

  • a string containing a CSS-style hex value (e.g. '#aaa' or '#8a2be2')

  • a string containing a CSS-style RGB notation (e.g. rgb(102,51,153))

These forms can be mixed and matched at will:

print(color('orange on gray', 'orange', 'gray'))
print(color('nice color', 'white', '#8a2be2'))

Note that any color name defined in the basic ANSI color set takes primacy over the CSS color names. Combined with the fact that terminals do not always agree which precise tone of blue should qualify as ANSI blue, there can be some ambiguity regarding the named colors. If you need full precision, specify the RGB color exactly. The parse_rgb function can be used to identify the correct definition according to the CSS standards.

Caveats

Unfortunately there is no guarantee that every terminal or console will support all the colors and styles that ANSI ostensibly defines. In fact, most implement a subset–often a rather small subset. Colors are often better supported than styles, for which you might get one or two of the most popular styles such as bold or underline. Might.

Whatever colors and styles are supported, there is no guarantee they will be accurately rendered. Even at this late date, over fifty years after the codes began to be standardized, support from terminals and output devices is limited, fragemented, and piecemeal.

ANSI codes evolved in an entirely different historical context from today’s. Both the Web and the idea of broad standardization were decades in the future. Display technology was low-resolution, colors were limited even when present, and color/style fidelity was not a major consideration. Vendors thought little or nothing of creating their own proprietary codes, implementing functions differently from other vendors, and/or co-opting codes previously in use for something else. Practical ANSI reference materials tend to include many phrases such as ‘hardly ever supported’ and ‘non-standard.’

We still use ANSI codes today not because they’re especially good, but because they’re the best, most-standard approach that pre-Web display systems (consoles, terminals, and the like) even remotely agreed upon. And even in this post-Web era, output of text to consoles and terminal windows endures as an important means of human-computer interaction. The good news, such is it is: The color and style specifications (“SGR” or “Select Graphic Rendition” in ANSI terminology) are the most-used and best-adhered-to portion of the whole ANSI show.

More Examples

# use some partial functions

from __future__ import print_function # so works on Python 2 and 3 alike
from colors import red, green, blue

print(red('This is red'))
print(green('This is green'))
print(blue('This is blue'))

Optionally you can add a background color and/or styles.:

print(red('red on blue', bg='blue'))
print(green('green on black', bg='black', style='underline'))

You can additionally specify one of the supported styles: none, bold, faint, italic, underline, blink, blink2, negative, concealed, crossed. While most devices support only a few styles, unsupported styles are generally ignored, so the only harm done is your text is less pretty and/or less formatted than you might like.

You can use multiple styles at once. Separate them with a +.:

print(red('very important', style='bold+underline'))

If you use this style often, you may want to create your own named style:

from functools import partial
from colors import color

important = partial(color, fg='red', style='bold+underline'))

print(important('very important'))

Utility Functions

In deailing with ANSI-styled text, it can be necessary or convenient to determine the “equivalent” text minus the styling. The function strip_color(s) does that, removing ANSI codes from s, returning its “plain text equivalent.”

You may also wish to determine the effective length of a string. If it contains ANSI color and styling codes, the builtin len() function will return the length of those codes as well, which is probably not what you want. So ansilen returns the “effective” length of the string, including only the non-ANSI characters. ansilen(s) is equivalent to len(strip_color(s)),

License

colors is licensed under the ISC 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

ansicolors-1.1.6.zip (20.3 kB view details)

Uploaded Source

Built Distribution

ansicolors-1.1.6-py2.py3-none-any.whl (13.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file ansicolors-1.1.6.zip.

File metadata

  • Download URL: ansicolors-1.1.6.zip
  • Upload date:
  • Size: 20.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for ansicolors-1.1.6.zip
Algorithm Hash digest
SHA256 abbcb8df81fd0245a6aaacf3342baa281dcf13a29c302a9612355f3b675362b2
MD5 d11ee244447fbad352be1524c3538f97
BLAKE2b-256 a73b2695aa5ecd634ad980f1cb0aa8977bb46da3cde8461e8a70a8bacd3482d8

See more details on using hashes here.

File details

Details for the file ansicolors-1.1.6-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for ansicolors-1.1.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e471e2364ecf78bd01868f9ad05b036aad3f572cba37278a3126d8b460812756
MD5 93cdfc84a2bdc32586795a061fdfe283
BLAKE2b-256 ca501f7d0da89bd9baa0093e682c768190e5f1802101c51a5e1d6fdd4e555ec5

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page