37 lines
1.2 KiB
Python
37 lines
1.2 KiB
Python
import logging
|
|
import datetime
|
|
import os
|
|
|
|
|
|
def create_logger(
|
|
save_logging_messages: bool, display_logging_messages: bool, log_stage_name: str
|
|
):
|
|
now = datetime.datetime.now()
|
|
dt_string_filename = now.strftime("%Y_%m_%d_%H_%M_%S")
|
|
|
|
logger = logging.getLogger("MyLittleLogger")
|
|
logger.setLevel(logging.DEBUG)
|
|
|
|
if save_logging_messages:
|
|
time_format = "%b %d %Y %H:%M:%S"
|
|
logformat = "%(asctime)s %(message)s"
|
|
file_formatter = logging.Formatter(fmt=logformat, datefmt=time_format)
|
|
os.makedirs("logs_" + log_stage_name, exist_ok=True)
|
|
file_handler = logging.FileHandler(
|
|
os.path.join("logs_" + log_stage_name, f"log_{dt_string_filename}.txt")
|
|
)
|
|
file_handler.setLevel(logging.INFO)
|
|
file_handler.setFormatter(file_formatter)
|
|
logger.addHandler(file_handler)
|
|
|
|
if display_logging_messages:
|
|
time_format = "%H:%M:%S"
|
|
logformat = "%(asctime)s %(message)s"
|
|
stream_formatter = logging.Formatter(fmt=logformat, datefmt=time_format)
|
|
|
|
stream_handler = logging.StreamHandler()
|
|
stream_handler.setLevel(logging.INFO)
|
|
stream_handler.setFormatter(stream_formatter)
|
|
logger.addHandler(stream_handler)
|
|
|
|
return logger
|