Skip to main content

Logging made simple.

Project description

logpie

Logging made simple.

This is a simple logging module with thread & file locking abilities.


Installation:

python -m pip install [--upgrade] logpie

Usage:

# your `main.py` module

from os.path import dirname, realpath, join
from sys import modules
from types import ModuleType

from cfgpie import get_config, CfgParser
from logpie import get_logger, Logger

# **************************** config constants: **************************** #

# main module
MODULE: ModuleType = modules.get("__main__")

# root directory
ROOT: str = dirname(realpath(MODULE.__file__))

# default config file path:
CONFIG: str = join(ROOT, "config", "cfgpie.ini")

# backup config params:
BACKUP: dict = {
    "LOGGER": {
        "basename": "logpie",  # if handler is `file`
        "folder": r"${DEFAULT:directory}\logs",
        "handlers": ["file"],  # or `console` or both (always as list)
        "level": 0,  # logs all messages above this level
    }
}

# NOTE: The constants above serve the usage example,
#       and you can use whatever suits you best.

# ********************** get `ConfigParser` instance: *********************** #

cfg: CfgParser = get_config(name="my_config")
cfg.set_defaults(directory=ROOT)
cfg.open(file_path=CONFIG, encoding="UTF-8", fallback=BACKUP)

# ************************* get `Logger` instance: ************************** #

# we can pass a config instance:
log: Logger = get_logger(name="my_logger", config=cfg)

or

# it will look for a config instance named `my_config`:
log: Logger = get_logger(name="my_logger", config="my_config")

or

# it will create and use its own config instance:
log: Logger = get_logger(name="my_logger", level="debug", handlers="file", basename="logpie")


if __name__ == '__main__':
    log.debug("Testing debug messages...")
    log.info("Testing info messages...")
    log.warning("Testing warning messages...")
    log.error("Testing error messages...")
    log.critical("Testing critical messages...")

By default, logging level is set to NOTSET (0) and it logs all messages.

The log file is prefixed with a date and will have an index number attached before the extension (ex: 2022-08-01_logpie.1.log). When it reaches 1 Mb the file handler will switch to another file by incrementing its index with 1.

The folder tree is by default structured as follows:

.
└───logs
    └───year (ex: 2022)
        └───month (ex: january)
            ├───2022-08-01_logpie.1.log
            ├───2022-08-01_logpie.2.log
            └───2022-08-01_logpie.3.log

When the current month changes, a new folder is created and the previous one is archived.


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

logpie-2.1.0.tar.gz (16.6 kB view details)

Uploaded Source

Built Distribution

logpie-2.1.0-py3-none-any.whl (18.6 kB view details)

Uploaded Python 3

File details

Details for the file logpie-2.1.0.tar.gz.

File metadata

  • Download URL: logpie-2.1.0.tar.gz
  • Upload date:
  • Size: 16.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.5

File hashes

Hashes for logpie-2.1.0.tar.gz
Algorithm Hash digest
SHA256 3e25fbcf4001c1476ff8281d62e137d880cfb9f767db4f31456a89c20bd82e21
MD5 c3aac6a89d91c57afaff095d280cba20
BLAKE2b-256 f7aa41d1a7e52950aad938feccef6abf4c3fe0d9b31e16e302a7f5c9cef51cb3

See more details on using hashes here.

File details

Details for the file logpie-2.1.0-py3-none-any.whl.

File metadata

  • Download URL: logpie-2.1.0-py3-none-any.whl
  • Upload date:
  • Size: 18.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.5

File hashes

Hashes for logpie-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f5bdc799a9c7323c9a43ebfd7c5f4ddca375fb73b25af403a33356b368812790
MD5 1f4773242c08d47ab4df7bf24fae1a46
BLAKE2b-256 bf0f67b3e6aa73a153bc1249d2f5a618b79153a04285021a4a47e335a6276eda

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