Python:创建异常日志装饰器
admin
2023-07-31 01:46:26
0

Python: How to Create an Exception Logging Decorator

exception_decor.py

import functools
import logging
 
def create_logger():
    \"\"\"
    Creates a logging object and returns it
    \"\"\"
    logger = logging.getLogger(\"example_logger\")
    logger.setLevel(logging.INFO)
 
    # create the logging file handler
    fh = logging.FileHandler(\"/path/to/test.log\")
 
    fmt = \'%(asctime)s - %(name)s - %(levelname)s - %(message)s\'
    formatter = logging.Formatter(fmt)
    fh.setFormatter(formatter)
 
    # add handler to logger object
    logger.addHandler(fh)
    return logger
 
 
def exception(function):
    \"\"\"
    A decorator that wraps the passed in function and logs 
    exceptions should one occur
    \"\"\"
    @functools.wraps(function)
    def wrapper(*args, **kwargs):
        logger = create_logger()
        try:
            return function(*args, **kwargs)
        except:
            # log the exception
            err = \"There was an exception in  \"
            err += function.__name__
            logger.exception(err)
 
            # re-raise the exception
            raise
    return wrapper

在该代码中,有两个函数。第一个函数创建了日志对象并返回该日志对象。第二个函数是我们的装饰器函数。我们在一个try/except中封装传递的函数,当logger中发生任何异常的时候,进行日志记录。并且我还记录了当异常发生时的函数名称。

现在让我们测试下该装饰器。


    from exception_decor import exception
     
    @exception
    def zero_divide():
        1 / 0
     
    if __name__ == \'__main__\':
        zero_divide()

运行以上测试代码后,会出现以下错误日志:

2016-06-09 08:26:50,874 - example_logger - ERROR - There was an exception in  zero_divide
Traceback (most recent call last):
  File \"/home/mike/exception_decor.py\", line 29, in wrapper
    return function(*args, **kwargs)
  File \"/home/mike/test_exceptions.py\", line 5, in zero_divide
    1 / 0
ZeroDivisionError: integer division or modulo by zero

传递一个 logger 到装饰器

# exception_logger.py
 
import logging
 
def create_logger():
    \"\"\"
    Creates a logging object and returns it
    \"\"\"
    logger = logging.getLogger(\"example_logger\")
    logger.setLevel(logging.INFO)
 
    # create the logging file handler
    fh = logging.FileHandler(r\"/path/to/test.log\")
 
    fmt = \'%(asctime)s - %(name)s - %(levelname)s - %(message)s\'
    formatter = logging.Formatter(fmt)
    fh.setFormatter(formatter)
 
    # add handler to logger object
    logger.addHandler(fh)
    return logger
 
logger = create_logger()

现在修改前面出现的装饰器,以便可以接受 logger 作为参数。

# exception_decor.py
 
import functools
 
 
def exception(logger):
    \"\"\"
    A decorator that wraps the passed in function and logs 
    exceptions should one occur
 
    @param logger: The logging object
    \"\"\"
 
    def decorator(func):
 
        def wrapper(*args, **kwargs):
            try:
                return func(*args, **kwargs)
            except:
                # log the exception
                err = \"There was an exception in  \"
                err += func.__name__
                logger.exception(err)
 
            # re-raise the exception
            raise
        return wrapper
    return decorator

最后修改测试脚本:

from exception_decor import exception
from exception_logger import logger
 
@exception(logger)
def zero_divide():
    1 / 0
 
if __name__ == \'__main__\':
    zero_divide()

相关内容

热门资讯

Mobi、epub格式电子书如... 在wps里全局设置里有一个文件关联,打开,勾选电子书文件选项就可以了。
定时清理删除C:\Progra... C:\Program Files (x86)下面很多scoped_dir开头的文件夹 写个批处理 定...
scoped_dir32_70... 一台虚拟机C盘总是莫名奇妙的空间用完,导致很多软件没法再运行。经过仔细检查发现是C:\Program...
500 行 Python 代码... 语法分析器描述了一个句子的语法结构,用来帮助其他的应用进行推理。自然语言引入了很多意外的歧义,以我们...
小程序支付时提示:appid和... [Q]小程序支付时提示:appid和mch_id不匹配 [A]小程序和微信支付没有进行关联,访问“小...
pycparser 是一个用... `pycparser` 是一个用 Python 编写的 C 语言解析器。它可以用来解析 C 代码并构...
微信小程序使用slider实现... 众所周知哈,微信小程序里面的音频播放是没有进度条的,但最近有个项目呢,客户要求音频要有进度条控制,所...
65536是2的几次方 计算2... 65536是2的16次方:65536=2⁶ 65536是256的2次方:65536=256 6553...
Apache Doris 2.... 亲爱的社区小伙伴们,我们很高兴地向大家宣布,Apache Doris 2.0.0 版本已于...
项目管理和工程管理的区别 项目管理 项目管理,顾名思义就是专注于开发和完成项目的管理,以实现目标并满足成功标准和项目要求。 工...