Files
luoluo/src/utils/logger.py
2026-03-18 15:48:40 +08:00

83 lines
2.2 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
"""
日志配置 - 使用标准库logging
"""
import sys
import logging
from pathlib import Path
from datetime import datetime
def setup_logger(log_dir: Path = None, level: str = "INFO"):
"""
配置日志系统
Args:
log_dir: 日志文件目录默认为项目根目录下的logs文件夹
level: 日志级别
"""
if log_dir is None:
log_dir = Path(__file__).parent.parent.parent / "logs"
log_dir.mkdir(exist_ok=True)
# 设置日志级别
log_level = getattr(logging, level.upper(), logging.INFO)
# 配置根日志记录器
logger = logging.getLogger()
logger.setLevel(logging.DEBUG)
# 清除现有处理器
logger.handlers.clear()
# 控制台处理器
console_handler = logging.StreamHandler(sys.stdout)
console_handler.setLevel(log_level)
console_format = logging.Formatter(
'%(asctime)s | %(levelname)-8s | %(name)s:%(funcName)s:%(lineno)d - %(message)s',
datefmt='%H:%M:%S'
)
console_handler.setFormatter(console_format)
logger.addHandler(console_handler)
# 文件处理器
log_file = log_dir / f"luoluo_{datetime.now().strftime('%Y-%m-%d')}.log"
file_handler = logging.FileHandler(log_file, encoding='utf-8')
file_handler.setLevel(logging.DEBUG)
file_format = logging.Formatter(
'%(asctime)s | %(levelname)-8s | %(name)s:%(funcName)s:%(lineno)d - %(message)s',
datefmt='%Y-%m-%d %H:%M:%S'
)
file_handler.setFormatter(file_format)
logger.addHandler(file_handler)
return logger
# 创建一个简单的logger别名兼容loguru的接口
class SimpleLogger:
"""简单的logger包装类提供类似loguru的接口"""
def __init__(self):
self._logger = logging.getLogger("LuoLuoTool")
def debug(self, message):
self._logger.debug(message)
def info(self, message):
self._logger.info(message)
def warning(self, message):
self._logger.warning(message)
def error(self, message):
self._logger.error(message)
def critical(self, message):
self._logger.critical(message)
# 全局logger实例
logger = SimpleLogger()