-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogger.py
31 lines (24 loc) · 1.1 KB
/
logger.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
# logger.py
import logging
import sys
from config import config
def get_logger(name: str, level: int = logging.WARNING) -> logging.Logger:
"""Tạo và cấu hình logger với tên cụ thể và mức độ log tùy chỉnh."""
logger = logging.getLogger(name)
logger.setLevel(level) # Đặt mức độ log tùy chỉnh
# Kiểm tra xem logger đã được cấu hình handler hay chưa
if not logger.handlers:
# Tạo formatter
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')
# Tạo file handler để ghi log vào file
file_handler = logging.FileHandler(config.log_path, encoding='utf-8')
file_handler.setFormatter(formatter)
# Tạo console handler để hiển thị log trên console
console_handler = logging.StreamHandler(sys.stdout)
console_handler.setFormatter(formatter)
# Thêm các handler vào logger
logger.addHandler(file_handler)
logger.addHandler(console_handler)
# Ngăn chặn log bị ghi nhiều lần
logger.propagate = False
return logger