Skip to main content

This project is a simple library to color text in the terminal with python.

Project description

CodeChroma

Simple python text coloring package

The "CodeChroma" project is a Python library for highlighting and coloring text in the terminal. With this library, users can highlight code syntax and color specific markdown elements, such as titles, links, parentheses and text in quotation marks.

Why the project?

The project was created with the aim of improving the readability and aesthetics of text in projects using the terminal. On many occasions, text in the terminal can be difficult to read due to its flat, uncolored format, which can make work difficult and decrease efficiency. For this reason, a Python library was developed to allow text highlighting and coloring in a simple and easy to implement way.

The library allows users to highlight code syntax and color specific markdown elements, such as titles, links, parentheses and text in quotation marks, which improves the readability of the text and makes it easier to understand. In addition, this library is easy to implement in any project as it can be used with a simple library method, making the integration process quick and easy.

Requirements

Features

  • Allows to identify the code passed as a string and return the text with the syntax of the language colored.
  • Allows you to color key elements of the markdown syntax such as code, titles, links, etc.
  • Allows quick and easy implementation of the colors to be used.

How to use

The library is simple to use and only requires installation and import.

pip install CodeChroma

The library allows you to color the text using only one method of the library for ease of use.

from CodeChroma import TerminalColors

# We create an instance of the library
termcolor = TerminalColors()

#  Sample text for coloring
text = \
"""
# Sintaxis de Java

## Variables

En Java, existen diferentes tipos de variables, como enteros, flotantes, caracteres y booleanos.
Además de variables de tipo objeto como String o Arrays. Es importante declarar el tipo de
variable correcto para evitar errores en tiempo de ejecución. Por ejemplo, si quieres
almacenar un valor numérico entero, se debe utilizar "int" como el tipo de dato.

'''java
int numeroEntero = 10;
float decimal = 3.14f;
char letra = 'A';
boolean verdaderoOFalso = true;
'''
"""

# We color the text with its method "colorize_text", the text passed by parameter
# The function returns a new string with the text already colored.
colored_text = termcolor.colorize_text(text)
# We can display the new text
print(colored_text)

Configuration

The library allows for a few extra settings, which allow the user to modify and color their text as needed.

Colors

The colors can be easily modified from the parameters assigned when creating the instance of the TerminalColors class, you can write the available color you need for each colorable element.

termcolor = TerminalColors(title="yellow", list_item="magenta", ...)

Another way to modify the colors of each element is from its elements attribute, for this it is necessary to pass some method either own of the library or personal (But it must be a method), that allows to color the text and to return the colored text.

colors = Colors()
termcolor = TerminalColors(title="yellow", list_item="magenta")
termcolor.elements = {
        "title": colors.bg_cyan,
        "block": colors.yellow,
        "list-item": colors.magenta,
        "url": colors.cyan,
        "parentheses": colors.light_red,
        "string": colors.light_green,
        "code": colors.yellow,
        "lang": colors.red
      }

Format

The TerminalColors class has some properties that modify how the string resulting from the coloring is displayed.

One of them is the programming language, with the view_lang property (boolean value, by default it is set to True) allows to modify if the identified language will be shown or not.

termcolor.view_lang = False

The following format_code modifies whether the code is returned with or without the markdown code block characters "````", by default it is set to True.

termcolor.format_code = False

Methods

The TerminalColors class has some coloring methods as needed.

FUNCTION PARAMS DESCRIPTION
coloring_text text:str This function receives a text as a parameter and allows coloring the string with markdown formatting and features.
color_code code:str This function allows you to pass a code as a string, the function will identify the language and color it according to its syntax if it finds the language.
detect_code_language code:str This function also allows you to receive a code as a string and it will return a string with the language you identified in the code.

Licence

MIT


Github LinkedIn

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

CodeChroma-1.5.0.tar.gz (9.0 kB view details)

Uploaded Source

File details

Details for the file CodeChroma-1.5.0.tar.gz.

File metadata

  • Download URL: CodeChroma-1.5.0.tar.gz
  • Upload date:
  • Size: 9.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for CodeChroma-1.5.0.tar.gz
Algorithm Hash digest
SHA256 e18dddc356e999b91165b937423bbf49e935733abea047c598fd001828341a5b
MD5 a5afd6378982d0c828c12e2806ac0166
BLAKE2b-256 999a53bbe8c4868693e6bf697e3e7020ca8c0f6b116cf49cf61f9908349b77df

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