首页 > 编程语言 > 详细

python 通过装饰器实现类的日志记载

时间:2019-01-22 14:45:04      阅读:201      评论:0      收藏:0      [点我收藏+]
import logging
from logging import FileHandler, Formatter
import os.path as fpath
from datetime import datetime
logfile = fpath.join(fpath.dirname(fpath.abspath(__file__)),datetime.now().strftime(%Y%m%d) + .log)

formatter = %(asctime)s %(levelname)-8s %(name)-15s %(funcName)s %(message)s
dateformatter = %Y-%m-%d %H:%M:%S
default_level = {
    critical: 50,
    error: 40,
    warning: 30,
    info: 20,
    debug: 10
}


def bindlog(level = debug):
    def wrapper(cls):
        print(cls)
        logger = logging.getLogger(cls.__name__)
        logger.setLevel(default_level[level])
        file_handle = FileHandler(logfile)
        file_handle.setFormatter(Formatter(formatter, dateformatter))
        logger.addHandler(file_handle)        
        def inner(*args, **kwargs):
            if not hasattr(cls, log):
                setattr(cls, log, logger)
            return(cls(*args, **kwargs))
        return inner            
    return wrapper
    

@bindlog()
class Test:
    
    
    def add(self):
        for _ in range(100):
            
            self.log.info(ceshi.)

 

python 通过装饰器实现类的日志记载

原文:https://www.cnblogs.com/alplf123/p/10303667.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!