#! /usr/bin/env python # coding=utf-8 from time import time def logged(when): def log(f,*args,**kargs): print("called: function:%s,args:%r,kargs:%r"%(f,args,kargs)) def pre_logged(f): def wrapper(*args,**kargs): log(f,*args,**kargs) return f(*args,**kargs) def post_logged(f): def wrapped(*args,**kargs): now=time() try: return f(*args,**kargs) finally: log(f,*args,**kargs) print("time delta:%s"%(time()-now)) return wrapped try: #从这里开始调用 return{"pre":pre_logged,"post":post_logged}[when] except Exception as e: print(e) @logged("post") def hello(name): print("hello",name) @logged("post") def test(a,b=1): print(a+b) hello("world") test(1,2)
用python 装饰器打log
上一篇:一步步来用C语言来写python扩展
下一篇:使用python模拟登陆百度
PythonTab微信公众号:
Python技术交流互助群 ( 请勿加多个群 ):
群1: 87464755
群2: 333646237
群3: 318130924
群4: 385100854