Skip to main content

Make your python CLI prints and logs simple but glamorous

Project description

glampy

This project intends to allow building useful, reliable and beautiful python CLIs with ease.

Installation

Stable release version:

pip install glampy

Latest development version:

pip install git+https://github.com/snaeil/glampy

Usage

Logging

The customized logger can be used in it's default optionated way or can be customized.
It is fully compatible with the standard python logging module.

The default style logs the following format, using dynamic colors for different log levels: [2024-01-01 12:00:00] [LEVEL] [LOGGER_NAME] Messages

# Example using the Logger class to log to stdout and a file:
from glampy.logging import Logger
logger = Logger("my_logger", log_file="my_log.log", log_level=logging.DEBUG)
logger.debug("This is a debug message that will be logged to stdout and the file.")

# Example using the Logger class to log to a file only:
from glampy.logging import Logger
logger = Logger("my_logger", console_handler=None, log_level=logging.DEBUG)
logger.debug("This is a debug message that will be logged to a file only.")

# Example using the Logger class to log to stdout only:
from glampy.logging import Logger
logger = Logger("my_logger", log_level=logging.WARNING)
logger.warning("This is a warning message that will be logged to stdout only.")
logger.info("This is an info message that will not be logged.")

# Example using custom log format:
from glampy.logging import Logger
custom_format = "%(asctime)s - %(name)s - %(levelname)s - %(message)s"
logger = Logger("my_logger", log_file="my_log.log", log_level=logging.INFO, log_format=custom_format)

# Example using advanced custom log format:
import logging
from glampy.logging import Logger
from glampy.style import Foreground_Colour, Style
class Formatter(logging.Formatter):
    def format(self, record: logging.LogRecord):
        # Do whatever you want with the record here, e.g. add colors based on level
        color = {
            logging.WARNING: Foreground_Colour.YELLOW,
            logging.ERROR: Foreground_Colour.RED,
            logging.FATAL: Foreground_Colour.RED,
            logging.INFO: Foreground_Colour.GREEN,
            logging.DEBUG: Foreground_Colour.CYAN,
        }.get(record.levelno, 0)
        self._style._fmt = f"[%(asctime)s] [{color}%(levelname)7s{Style.RESET_ALL}] [{Foreground_Colour.MAGENTA}%(name){Style.RESET_ALL}] %(message)s"
        return super().format(record)
advanced_format = Formatter()
logger = Logger("my_logger", log_file="my_log.log", log_level=logging.INFO, log_format=advanced_format)

Style

The style module provides a simple way to style text in the terminal.
See the source code for all available styles.

from glampy.style import Style, Sign, Foreground_Colour, Background_Colour

# Example using the Style class to style text:
print(f"{Sign.WARNING} The word {Style.bold}bold{Style.RESET_ALL} is not {style.italic}italic{Style.RESET_ALL}.")

Contributing

Contributions are welcome! For feature requests, bug reports or questions, please open an issue. For code contributions, please open a pull request.

The development environment can be set up using nix and devenv:

  1. Install nix package manager: bash <(curl -L https://nixos.org/nix/install) --no-daemon
  2. Make sure, your ~/.config/nix/nix.conf contains the following lines:
    experimental-features = nix-command flakes
    
  3. Install devenv by running:
    nix profile install --accept-flake-config 'nixpkgs#devenv'
    
  4. Install nix-direnv by running:
    nix profile install 'nixpkgs#nix-direnv'
    
    Then add nix-direnv to $HOME/.config/direnv/direnvrc:
    source $HOME/.nix-profile/share/nix-direnv/direnvrc
    
  5. Hook direnv into your shell by adding a line to your shell's configuration file (e.g. ~/.bashrc), as described in the direnv documentation:
  6. You might have to open a new shell to make the changes take effect.

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

glampy-0.5.0.tar.gz (5.0 kB view details)

Uploaded Source

Built Distribution

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

glampy-0.5.0-py3-none-any.whl (6.1 kB view details)

Uploaded Python 3

File details

Details for the file glampy-0.5.0.tar.gz.

File metadata

  • Download URL: glampy-0.5.0.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.12.1 Linux/6.11.0-1018-azure

File hashes

Hashes for glampy-0.5.0.tar.gz
Algorithm Hash digest
SHA256 d1c43051c8ec9898b7b2f12c5c910a7a9f83266792bc4937d88c2f6ad2911756
MD5 7609c72a9f0ac2904c6b74bc70598159
BLAKE2b-256 3d7feb626082d2265c0b8dffc720a3da64bfe9cf058069570e8a1289ff20f098

See more details on using hashes here.

File details

Details for the file glampy-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: glampy-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 6.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.12.1 Linux/6.11.0-1018-azure

File hashes

Hashes for glampy-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b396094aff3b3c97b4c99cfdb64b8ae75ef2738c57e27655c19bc61fe4235cb3
MD5 7ccf6298222bb3f6788a6956f0e9e96e
BLAKE2b-256 e1f91c0d77e067f7351f84fb4fd7d25780e27bbc2bafee835f8a8f8a297d7981

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