Spaces:
Sleeping
Sleeping
import logging | |
import sys | |
from datetime import datetime | |
from loguru import logger as _logger | |
from pathlib import Path | |
import sys | |
_print_level = "INFO" | |
PROJECT_ROOT = Path(sys.path[0]) # Assuming the script is run from the project root | |
def define_log_level(print_level="INFO", logfile_level="DEBUG", name: str = None): | |
"""Adjust the log level to above level""" | |
global _print_level | |
_print_level = print_level | |
current_date = datetime.now() | |
formatted_date = current_date.strftime("%Y%m%d%H%M%S") | |
log_name = ( | |
f"{name}_{formatted_date}" if name else formatted_date | |
) # name a log with prefix name | |
_logger.remove() | |
_logger.add(sys.stderr, level=print_level) | |
_logger.add(PROJECT_ROOT / f"logs/{log_name}.log", level=logfile_level) | |
return _logger | |
# Module-level default logger | |
logger = define_log_level() | |