python 使用装饰器并记录log的示例代码


Posted in Python onJuly 12, 2019

1.首先定义一个log文件

# -*- coding: utf-8 -*-
import os
import time
import logging
import sys
log_dir1=os.path.join(os.path.dirname(os.path.dirname(__file__)),"logs")
today = time.strftime('%Y%m%d', time.localtime(time.time()))
full_path=os.path.join(log_dir1,today)
if not os.path.exists(full_path):
 os.makedirs(full_path)
log_path=os.path.join(full_path,"facebook.log")
def get_logger():
  # 获取logger实例,如果参数为空则返回root logger
  logger = logging.getLogger("facebook")
  if not logger.handlers:
   # 指定logger输出格式
   formatter = logging.Formatter('%(asctime)s %(levelname)-8s: %(message)s')
 
   # 文件日志
   file_handler = logging.FileHandler(log_path,encoding="utf8")
   file_handler.setFormatter(formatter) # 可以通过setFormatter指定输出格式
 
   # 控制台日志
   console_handler = logging.StreamHandler(sys.stdout)
   console_handler.formatter = formatter # 也可以直接给formatter赋值
 
   # 为logger添加的日志处理器
   logger.addHandler(file_handler)
   logger.addHandler(console_handler)
 
   # 指定日志的最低输出级别,默认为WARN级别
   logger.setLevel(logging.INFO)
  # 添加下面一句,在记录日志之后移除句柄
  return logger

2.然后定义一个装饰器文件

在这里引用wraps,一个装饰器的装饰器,目的为了保持引用进来的函数名字不发生变化

#!/usr/bin/env python 
# encoding: utf-8
from functools import wraps
from logger.log import get_logger
import traceback
def decoratore(func):
 @wraps(func)
 def log(*args,**kwargs):
  try:
   print("当前运行方法",func.__name__)
   return func(*args,**kwargs)
  except Exception as e:
   get_logger().error(f"{func.__name__} is error,here are details:{traceback.format_exc()}")
 return log

3.在使用的时候直接在函数上面引用即可

@decorator
def start():
 print("666")

以上这篇python 使用装饰器并记录log的示例代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python client使用http post 到server端的代码
Feb 10 Python
python局部赋值的规则
Mar 07 Python
用Python和MD5实现网站挂马检测程序
Mar 13 Python
python实现神经网络感知器算法
Dec 20 Python
详解Django+Uwsgi+Nginx的生产环境部署
Jun 25 Python
Python 判断图像是否读取成功的方法
Jan 26 Python
pandas和spark dataframe互相转换实例详解
Feb 18 Python
python实现查找所有程序的安装信息
Feb 18 Python
python pandas.DataFrame.loc函数使用详解
Mar 26 Python
Django使用Profile扩展User模块方式
May 14 Python
关于Python不换行输出和不换行输出end=““不显示的问题(亲测已解决)
Oct 27 Python
python tkinter实现下载进度条及抖音视频去水印原理
Feb 07 Python
如何使用python爬虫爬取要登陆的网站
Jul 12 #Python
Pycharm使用之设置代码字体大小和颜色主题的教程
Jul 12 #Python
python增加图像对比度的方法
Jul 12 #Python
Python 控制终端输出文字的实例
Jul 12 #Python
在Django的View中使用asyncio的方法
Jul 12 #Python
检测python爬虫时是否代理ip伪装成功的方法
Jul 12 #Python
在PyCharm中控制台输出日志分层级分颜色显示的方法
Jul 11 #Python
You might like
非洲第一个咖啡超凡杯大赛承办国—卢旺达的咖啡怎么样
2021/03/03 咖啡文化
Smarty+QUICKFORM小小演示
2007/02/25 PHP
php中JSON的使用与转换
2015/01/14 PHP
PHP获取本周所有日期或者最近七天所有日期的方法
2018/06/20 PHP
PHP DB 数据库连接类定义与用法示例
2019/03/11 PHP
使用laravel指定日志文件记录任意日志
2019/10/17 PHP
防止Node.js中错误导致进程阻塞的办法
2016/08/11 Javascript
微信JS-SDK选取手机照片上传功能
2017/04/21 Javascript
源码分析Vue.js的监听实现教程
2017/04/23 Javascript
Angular4学习教程之HTML属性绑定的方法
2018/01/04 Javascript
微信小程序自定义导航栏
2018/12/31 Javascript
jQuery中each和js中forEach的区别分析
2019/02/27 jQuery
微信小程序如何获取群聊的openGid以及名称详解
2019/07/17 Javascript
vue 设置 input 为不可以编辑的实现方法
2019/09/19 Javascript
vue实现吸顶、锚点和滚动高亮按钮效果
2019/10/21 Javascript
Layer UI表格列日期格式化及取消自动填充日期的实现方法
2020/05/10 Javascript
Python3 加密(hashlib和hmac)模块的实现
2017/11/23 Python
在CentOS6上安装Python2.7的解决方法
2018/01/09 Python
Python坐标线性插值应用实现
2019/11/13 Python
Python 实现训练集、测试集随机划分
2020/01/08 Python
Python爬虫HTPP请求方法有哪些
2020/06/03 Python
python实现自动打卡的示例代码
2020/10/10 Python
python 使用csv模块读写csv格式文件的示例
2020/12/02 Python
浅谈Selenium+Webdriver 常用的元素定位方式
2021/01/13 Python
Abbott Lyon官网:女士手表、珠宝及配件
2020/12/26 全球购物
如果NULL定义成#define NULL((char *)0)难道不就可以向函数传入不加转换的NULL了吗
2012/02/15 面试题
好的自荐信包括什么内容
2013/11/07 职场文书
中餐厅主管的职责范文
2014/02/04 职场文书
小学庆六一活动方案
2014/02/28 职场文书
班风学风建设方案
2014/05/06 职场文书
4s店销售经理岗位职责
2014/07/19 职场文书
七年级地理教学计划
2015/01/22 职场文书
机修车间主任岗位职责
2015/04/08 职场文书
2016年中秋节慰问信
2015/12/01 职场文书
Python基础之元编程知识总结
2021/05/23 Python
Python中rapidjson参数校验实现
2021/07/25 Python