前言
由于每次写代码的时候都需要写日志记录,就想着把它封装起来,做成装饰器,这样用着也方便,代码也简洁,所以就进入对python装饰器的研究中。
一、python装饰器的基本知识
在这里也不进行太多概念的描述了,有问题可以直接百度查找相关概念。
装饰器说白了就是将一个函数包装起来,在该函数的外面嵌套一层函数,将该函数装饰起来,做一些操作之后再返回该函数的运行结果,也就是将函数当参数传入到另一个函数中。如下代码可以很直观得看出,在目标函数之前打印”新添加的功能“
#最简单的装饰器了
def outer(func):
def inner(*args, **kwargs):
#do something
print('新添加的功能')
return func(*args, **kwargs)
return inner
python装饰器分几种,分别是函数装饰器和类装饰器,再分为装饰类和装饰函数,在此也不多赘述,可以自行百度,本次只是想简单做一个记录而已。
二、逐步进行
第一步:制作一个在函数执行错误时,自动将错误写入文件保存起来
import time
import os
import logging
from functools import wraps
#先制作了一个带参数的日志logger函数
def setExceptionLogger(name):
logger = logging.getLogger('exception')
logger.setLevel(logging.INFO)
if not os.path.exists('logs'):
os.makedirs('logs')
fh = logging.FileHandler(os.path.realpath(os.path.join('logs', 'log_{}_{}.log'.format(name, time.strftime('%Y%m%d')))))
fmt = "\n[%(asctime)s-%(name)s-%(levelname)s]: %(message)s"
formatter = logging.Formatter(fmt)
fh.setFormatter(formatter)
logger.addHandler