封装写日志的类
Posted 彼得潘jd
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了封装写日志的类相关的知识,希望对你有一定的参考价值。
import logging
from logging import handlers
class MyLogger():
def __init__(self,file_name,level=‘info‘,backCount=5,when=‘D‘):
logger = logging.getLogger() # 先实例化一个logger对象,先创建一个办公室
logger.setLevel(self.get_level(level)) # 设置日志的级别
cl = logging.StreamHandler() # 负责往控制台输出的
bl = handlers.TimedRotatingFileHandler(filename=file_name, when=when,
interval=1, backupCount=backCount, encoding=‘utf-8‘)
fmt = logging.Formatter(‘%(asctime)s - %(pathname)s[line:%(lineno)d] - %(levelname)s: %(message)s‘)
# 指定日志的格式
cl.setFormatter(fmt) # 设置控制台输出的日志格式
bl.setFormatter(fmt) # 设置文件里面写入的日志格式
logger.addHandler(cl) # 把已经调教好的人放到办公室里
logger.addHandler(bl) # 把已经调教好的人放到办公室里
self.logger=logger
def get_level(self,str):
level={
‘debug‘:logging.DEBUG,
‘info‘: logging.INFO,
‘warn‘: logging.WARNING,
‘error‘: logging.ERROR
}
str=str.lower()
return level.get(str)
lw_log = MyLogger(‘lw.log‘,‘debug‘)
lw_log.logger.warning(‘哈哈哈‘)
以上是关于封装写日志的类的主要内容,如果未能解决你的问题,请参考以下文章