Overview — loguru documentation

PHOTO EMBED

Mon Aug 19 2024 14:29:25 GMT+0000 (Coordinated Universal Time)

Saved by @theshyxin

class InterceptHandler(logging.Handler):
    def emit(self, record: logging.LogRecord) -> None:
        # Get corresponding Loguru level if it exists.
        level: str | int
        try:
            level = logger.level(record.levelname).name
        except ValueError:
            level = record.levelno

        # Find caller from where originated the logged message.
        frame, depth = inspect.currentframe(), 0
        while frame and (depth == 0 or frame.f_code.co_filename == logging.__file__):
            frame = frame.f_back
            depth += 1

        logger.opt(depth=depth, exception=record.exc_info).log(level, record.getMessage())

logging.basicConfig(handlers=[InterceptHandler()], level=0, force=True)
content_copyCOPY

https://loguru.readthedocs.io/en/stable/overview.html#entirely-compatible-with-standard-logging