python——记录一次制作日志装饰器

前言

  由于每次写代码的时候都需要写日志记录,就想着把它封装起来,做成装饰器,这样用着也方便,代码也简洁,所以就进入对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
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值