Python使用修饰器进行异常日志记录操作示例
本文实例讲述了Python使用修饰器进行异常日志记录操作。分享给大家供大家参考,具体如下:
当脚本中需要进行的的相同的异常操作很多的时候,可以用修饰器来简化代码。比如我需要记录抛出的异常:
在log_exception.py文件中,
importfunctools importlogging defcreate_logger(): logger=logging.getLogger("test_log") logger.setLevel(logging.INFO) fh=logging.FileHandler("test.log") fmt="[%(asctime)s-%(name)s-%(levelname)s]:%(message)s" formatter=logging.Formatter(fmt) fh.setFormatter(formatter) logger.addHandler(fh) returnlogger deflog_exception(fn): @functools.wraps(fn) defwrapper(*args,**kwargs): logger=create_logger() try: fn(*args,**kwargs) exceptExceptionase: logger.exception("[Errorin{}]msg:{}".format(__name__,str(e))) raise returnwrapper
在test.py文件中:
fromlog_exceptionimportlog_exception @log_exception defreciprocal(x): return1/x if__name__=="__main__": reciprocal(0)
在test.log文件中可以看到以下错误信息:
[2017-11-2623:37:41,012-test_log-ERROR]:[Errorin__main__]msg:integerdivisionormodulobyzero
Traceback(mostrecentcalllast):
File"",line16,inwrapper
fn(*args,**kwargs)
File"",line3,inreciprocal
return1/x
ZeroDivisionError:integerdivisionormodulobyzero
参考:
1.https://wiki.python.org/moin/PythonDecorators
2.https://www.blog.pythonlibrary.org/2016/06/09/python-how-to-create-an-exception-logging-decorator/
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python日志操作技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。