python装饰器函数传参
python装饰器函数传参
装饰器
装饰器是一个返回函数的高阶函数。
- 装饰器常见用法:
打印日志
def logger(func):def wrapper(*args, **kw):print 'do {}'.format(func.__name__)func(*args, **kw)print 'finish'return wrapper@logger
def add(x,y):print '{} + {} = {}'.format(x,y,x+y)add(3,5)
在函数执行前,打印一行日志do...
;函数执行结束,打印一行日志finish
。执行结果如下:
do add
3 + 5 = 8
finish
计算时间
import timedef timer(func):def wrapper(*args, **kw):t1 = time.time()func(*args,**kw)t2 = time.time()cost_time = t2 - t1print 'cost time: {} s'.format(cost_time)return wrapper@timer
def cost_time(sleep_time):time.sleep(sleep_time)cost_time(10)
- 带参数的函数装饰器
def say_hello(country):def wrapper(func):def decorate(*args,**kw):if country == 'en':print 'hello'elif country == 'usa':print 'hi'else:returnfunc(*args,**kw)return decoratereturn wrapper@say_hello("usa")
def usa():print 'i am from usa'@say_hello("en")
def en():print 'i am from england'usa()
print '----------------------'
en()
装饰器本身是一个函数,使用两层嵌套传参,执行结果如下:
hi
i am from usa
----------------------
hello
i am from england
- 不带参数的类装饰器
基于类装饰器的实现,必须实现__call__
和__init__
两个内置函数。
__init__
:接收被装饰函数
__call__
:实现装饰逻辑
class logger(object):def __init__(self,func):self.func = funcdef __call__(self,*args,**kwargs):print 'the function {}() is running...'\.format(self.func.__name__)return self.func(*args,**kwargs)@logger
def say(something):print 'say {}!'.format(something)say('hello')
运行结果如下:
the function say() is running...
say hello!
- 带参数的类装饰器
带参数和不带参数的类装饰器有很大的不同。
__init__
:不再接收被装饰函数,而是接收传入参数
__call__
:接收被装饰函数,实现装饰逻辑
class logger(object):def __init__(self,level='INFO'):self.level = leveldef __call__(self,func):def wrapper(*args,**kwargs):print '{level}: the function {func} () is running...'\.format(level=self.level, func=func.__name__)func(*args,**kwargs)return wrapper@logger(level='WARNING')
def say(something):print 'say {}!'.format(something)say('hello')
运行结果如下:
WARNING: the function say () is running...
say hello!
函数的参数
- 位置参数
def power(x, n):s = 1while n > 0:n = n - 1s = s * xreturn s
power(x, n)
函数有两个参数:x
和n
,这两个参数都是位置参数,调用函数时,传入的两个值按照位置顺序依次赋值给参数x
和n
。
- 默认参数
def power(x, n=2):s = 1while n > 0:n = n - 1s = s * xreturn s
power(x, n)
函数有两个参数:x
和n
,如果想在不传入n
值时,默认计算x
的平方,此时可以将n
设为默认值2。
- 可变参数(*args)
def function(f_arg, *args):print f_arg, type(f_arg)print args, type(args)
nums = ['a','b','c']
function(1,2,*nums)
定义可变参数时,需要在参数前面加一个*
号,可变参数的个数是可变的。在函数内部,参数*args
接收到的是一个tuple
。输出结果如下:
1 <type 'int'>
(2, 'a', 'b', 'c') <type 'tuple'>
- 关键字参数(**kwargs)
def person(name,age,**kwargs):print 'name:',name,'age:',age,'other:',kwargs,type(kwargs)person('mark',30,city='shanghai')
**kwargs
允许将不定长度的键值对,作为参数传递给一个函数,关键字参数在函数内部自动组装为一个dict
。输出结果如下:
name: mark age: 30 other: {'city': 'shanghai'} <type 'dict'>
- 将函数作为参数传递给另一个函数
def hi():return 'hi friends'def function(func):print 'just test'print func()function(hi)
function()
函数将hi
函数作为参数接收,输出结果如下:
just test
hi friends
time模块
- 获取当前时间
>>> time.localtime()
time.struct_time(tm_year=2019, tm_mon=8, tm_mday=21, tm_hour=14, tm_min=31, tm_sec=18, tm_wday=2, tm_yday=233, tm_isdst=0)
- 获取格式化的时间
>>> time.ctime()
'Wed Aug 21 14:51:28 2019'
>>> time.asctime()
'Wed Aug 21 14:51:34 2019'
- 格式化日期
>>> time.strftime('%Y-%m-%d %H:%M:%S',time.localtime())
'2019-08-21 14:35:02'
>>> time.strftime('%a %b %d %H:%M:%S %Y',time.localtime())
'Wed Aug 21 14:36:09 2019'
- 计算运行时间
import time
start = time.time()
time.sleep(2)
end = time.time()
print end-start
python装饰器函数传参相关推荐
- 在Python中的无参装饰器和有参装饰器
装饰器特点: 1.开放封闭原则,即对扩展是开放的,对修改时封闭的: 2.装饰器本质可以是任意可调用的对象,被装饰的对象也可以是任意可调用对象: 3.装饰器的功能是在不修改被装饰器对象源代码以及被装饰器 ...
- python中的无参装饰器和有参装饰器
python中的无参装饰器和有参装饰器 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 装饰器特点: 1>.开放封闭原则,即对扩展是开放的,对修改时封闭的: 2>.装饰器 ...
- python装饰器传参与不传参_Python装饰器不会传参?别着急,这篇文章为你解惑
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是Python专题的第13篇文章,上一篇文章当中我们介绍了Python装饰器的定义和基本的用法,这篇文章我们一起来学习一下Python装 ...
- Python装饰器总结,带你几步跨越此坑!
欢迎添加华为云小助手微信(微信号:HWCloud002 或 HWCloud003),输入关键字"加群",加入华为云线上技术讨论群:输入关键字"最新活动",获取华 ...
- python 装饰器实现事件绑定_Python装饰器是怎么实现的?
Python中的装饰器是通过利用了函数特性的闭包实现的,所以在讲装饰器之前,我们需要先了解函数特性,以及闭包是怎么利用了函数特性的 ① 函数特性 python中的函数特性总的来说有以下四点: 1. 函 ...
- python装饰器使用多吗_如何理解Python装饰器?
Python中的装饰器是通过利用了函数特性的闭包实现的,所以在讲装饰器之前,我们需要先了解函数特性,以及闭包是怎么利用了函数特性的 ① 函数特性 python中的函数特性总的来说有以下四点: 1. 函 ...
- 一文读懂Python 装饰器函数
[摘要] Python装饰器的学习笔记 1. 初识装饰器 接下来,我们通过一个例子来为大家讲解这个装饰器: 需求介绍:你现在xx科技有限公司的开发部分任职,领导给你一个业务需求让你完成:让你写代码测试 ...
- python装饰器与闭包_Python 装饰器和闭包
Python 装饰器和闭包 装饰器是 Python 中常见的语法糖,这篇文章讲了闭包和装饰器的原理,并且分析了函数中变量的作用域,以及尝试总结了常见的坑. 装饰器基础 首先来看看装饰器的定义:装饰器本 ...
- python装饰器作用-如何理解Python装饰器?
晚上失眠,怒上知乎答题! 刚好最近我的python专栏里写过一篇装饰器相关的,不说废话,直接上干货! /> 目录如下:1.装饰器是什么? 2.如何使用装饰器? 3.内置装饰器 一.装饰器是什么? ...
最新文章
- 企业级IT运维平台的发展趋势与规划要点
- git的一些知识梳理以及命令操作
- Linux数据报文接收发送总结3
- C#中Attribute的继承
- HDU 3788 ZOJ问题
- 关于.net core http error 502.5 - process failure
- #1081 : 最短路径·一(Dijkstra)
- update字段变更SpringBoot @JsonProperty的使用属性的名称序列化为另外一个名称
- 【332】Machine Learning
- bzoj 1096: [ZJOI2007]仓库建设(斜率DP)
- 运维派送红包福利,参与就有!
- 软件工程-软件测试和系统运维
- jvm核心技术梳理(持续更新)
- windows10启动项修复||an operating system wasn't found解决办法
- 幼儿园c ch语言教育,幼儿园语言教育内容之三——听说游戏
- python画图代码100行_用100行Python代码告诉你国庆那些景点爆满!
- 关于AutoCAD启动速度慢的分析
- RTKLib的Manual基础解读
- Idea中设置护眼绿
- 在线Cron表达式解析工具使用说明