-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlog_config.py
31 lines (26 loc) · 965 Bytes
/
log_config.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
30
31
import os
import logging
from logging.handlers import RotatingFileHandler
# Create logs directory if it doesn't exist
logs_dir = os.path.join(os.path.expanduser('~'), 'display_programme/logs')
os.makedirs(logs_dir, exist_ok=True)
# Set up root logger
logger = logging.getLogger()
logger.setLevel(logging.DEBUG)
# Create formatters
console_formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
file_formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
# Console handler
console_handler = logging.StreamHandler()
console_handler.setLevel(logging.DEBUG)
console_handler.setFormatter(console_formatter)
logger.addHandler(console_handler)
# Rotating file handler
file_handler = RotatingFileHandler(
os.path.join(logs_dir, 'app.log'),
maxBytes=1024*1024, # 1MB
backupCount=5
)
file_handler.setLevel(logging.DEBUG)
file_handler.setFormatter(file_formatter)
logger.addHandler(file_handler)