摘要:第一個函數創建了日志對象并返回該日志對象。第二個函數是我們的裝飾器函數。我們在一個中封裝傳遞的函數,當中發生任何異常的時候,進行日志記錄。
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()
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/37996.html
摘要:內置函數實現對可迭代對象進行進一步處理。文件文件的打開權限打開文件,文件不存在報異常寫入文件,文件不存在則創建。文件不存在則創建。追加文件,具有讀寫權限。 Python基礎類型: 1.Tuple元組,內容不可改變,但是允許元素內部存在list等類型的元素,并且允許改變列表的值,所謂內容不可變指的是在內存中指向的地址是不變的。 temp=(1,2,[3,4]) temp[-1]....
摘要:譯者說于年月日發布,該版本正式支持的關鍵字,并且用舊版本編譯同樣可以使用這兩個關鍵字,這無疑是一種進步。其次,這是最后一個支持和的版本了,在后續的版本了會移除對它們的兼容。 譯者說 Tornado 4.3于2015年11月6日發布,該版本正式支持Python3.5的async/await關鍵字,并且用舊版本CPython編譯Tornado同樣可以使用這兩個關鍵字,這無疑是一種進步。其次...
閱讀 3082·2021-09-28 09:43
閱讀 915·2021-09-08 09:35
閱讀 1452·2019-08-30 15:56
閱讀 1197·2019-08-30 13:00
閱讀 2744·2019-08-29 18:35
閱讀 1838·2019-08-29 14:07
閱讀 3446·2019-08-29 13:13
閱讀 1343·2019-08-29 12:40