-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathlogHelper.py
29 lines (22 loc) · 1.05 KB
/
logHelper.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import logging
from config import global_logging_txt
def setup_logger(logger_name, output_file=None):
# Create a logger object
logger = logging.getLogger(logger_name)
logger.setLevel(logging.INFO) # Set the logging level to INFO
logger.propagate = False # Prevent log messages from being duplicated in the root logger
# Common formatter for all handlers
formatter = logging.Formatter('[%(asctime)s.%(msecs)03d] %(message)s', datefmt='%H:%M:%S')
# Always log to the default "logging.txt" file
# file_handler = logging.FileHandler(filename='your_log_file.log', encoding='utf-8')
default_fh = logging.FileHandler(filename=global_logging_txt, encoding='utf-8')
default_fh.setLevel(logging.INFO)
default_fh.setFormatter(formatter)
logger.addHandler(default_fh)
# Additionally, log to another file if output_file is specified
if output_file is not None:
fh = logging.FileHandler(output_file)
fh.setLevel(logging.INFO)
fh.setFormatter(formatter)
logger.addHandler(fh)
return logger