logger模块
对python项目的logger模块做初始化配置
1.编码utf-8
2.根据时间跟换文件名
3.保存天数7
4.日志格式
注意:当多进程操作同一个logger对象是,会报错操作文件冲突。
#!coding=utf-8
import os
import re
import logging
from logging.handlers import TimedRotatingFileHandler
def setup_log(log_name):
# 创建logger对象。传入logger名字
logger = logging.getLogger(log_name)
log_path = os.path.join("./log", log_name)
print(log_path)
# 设置日志记录等级
logger.setLevel(logging.INFO)
# interval 滚动周期,
# when="MIDNIGHT", interval=1 表示每天0点为更新点,每天生成一个文件
# backupCount 表示日志保存个数
file_handler = TimedRotatingFileHandler(
filename=log_path, when="MIDNIGHT", interval=1, backupCount=7, encoding="utf-8"
)
# filename="mylog" suffix设置,会生成文件名为mylog.2020-02-25.log
file_handler.suffix = "%Y-%m-%d.log"
# extMatch是编译好正则表达式,用于匹配日志文件名后缀
# 需要注意的是suffix和extMatch一定要匹配的上,如果不匹配,过期日志不会被删除。
file_handler.extMatch = re.compile(r"^\d{4}-\d{2}-\d{2}.log$")
# 定义日志输出格式
file_handler.setFormatter(
logging.Formatter(
"[%(asctime)s] [%(process)d] [%(levelname)s] - %(module)s.%(funcName)s (%(filename)s:%(lineno)d) - %(message)s"
)
)
logger.addHandler(file_handler)
return logger
logger = None
if not logger:
logger = setup_log("crawler.log")