封装好日志的类 logging


import
logging from logging import handlers class MyLogger(): def __init__(self,file_name,level='info',backCount=5,when='D'): #默认参数level级别是字典的value,bacuCount为5个,默认按D天生成,这样在实例化时,默认可以只传一个filename 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的级别 level = { 'debug':logging.DEBUG, 'info':logging.INFO, 'warn':logging.WARNING, 'error':logging.ERROR } str = str.lower() #将str都转化成小写 return level.get(str)

因此,封装好后,可以直接实例化并调用:

logs = MyLogger(date.log','dubug')

logs.logger.warning(‘这个bug级别是debug级别。。。’)

控制台输出:

生成的日志文件:(因为设置的when是D,按天生成的)

 

转载于:https://www.cnblogs.com/fancyl/p/9105726.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值