python3 最常用的三种装饰器语法汇总

python3 最常用的三种装饰器语法汇总

目录

python3 最常用的三种装饰器语法总结

1.简述语法

2.不带参数的函数的装饰器

3.带参数的函数的装饰器

python3 最常用的三种装饰器语法总结 1.简述语法

装饰器也叫函数装饰器,主要作用是在不修改原来函数的代码情况下(函数本身不会被修改,执行方式也不变化),增加的一个"装饰"函数,把原来的函数当成一个整体,像传参一样给这个函数使用,并返回这个"函数"。这个过程中我们增加一些函数相关的代码,当函数被执行的时候,就会一起执行,相当于让函数增加了更多的功能。
常用的方面:
1.1为函数增加日志记录功能:许多函数写的时候,并没有写日志记录功能,通过统一添加日志记录的装饰器,就无需更改代码,从而实现记录的功能。
1.2为函数实现验证功能:函数执行的时候,增加验证是否合规的装饰器,这是一些安全的措施,有时候非常必要。
1.3补救函数功能:项目结束后,发现重大BUG,可以通过过增加装饰器的方式修复,大量降低工作量。

2.不带参数的函数的装饰器

理解:@符号就是写一个装饰器,最基本的装饰器,就是写一个函数,并返回一个传入的参数。本质就是把整个函数当成了参数,并返回,这个过程没有执行函数,只增加了一个描述信息,如:国家。

def mycountry(m): country = "china" print(country) return m @mycountry def myname(): name = "chengruofei" print(name) return name myname()

执行结果:

python myname.py 
china
chengruofei

备注:
把@符号理解成省略了第一步的赋值,会不会豁然开朗:
myname = mycountry(myname)
myname()

3.带参数的函数的装饰器

**理解:**只需要在装饰器函数中,增加一个函数,并且里面一定要组合传入的“两个参数”为新的函数,此时返回值就变成了构造的函数。

def mycountry(m): country = "china" print(country) def myb(bb): m(bb) print("TEST boy") return myb @mycountry def myname(b): name = "chengruofei" print(name) print("I am a :",b) return name myname("boy")

执行结果:

china
chengruofei
('I am a :', 'boy')
TEST boy

备注:
通过装饰器的函数返回值,就丢失了。

4.带参数的装饰器

**理解:**本来装饰器是没有参数的,参数是根据函数的定义与否去设定的。但是有时候装饰器是个复杂的函数,集合了大量的功能,就需要带入参数去执行合适的装饰器函数。只需要在原本的解释器外层加上一层函数,并将中间层函数作为整体返回。

def myID(i): if i == 'mycountry': def mycountry(m): country = "china" print(country) def myb(bb): m(bb) print("TEST boy") return myb return mycountry else: def myschool(m): school = "shijiazhuangjisuanjizhiyejishuxueyuan" print("I graduated from ",school) def myb(bb): m(bb) print("TEST boy") return myb return myschool @myID('myschool') def myname(b): name = "chengruofei" print(name) print("I am a :",b) return name myname("boy")

执行结果:

('I graduated from ', 'shijiazhuangjisuanjizhiyejishuxueyuan')
chengruofei
('I am a :', 'boy')
TEST boy

到此这篇关于python3 最常用的三种装饰器语法总结的文章就介绍到这了,更多相关python3装饰器语法内容请搜索易知道(ezd.cc)以前的文章或继续浏览下面的相关文章希望大家以后多多支持易知道(ezd.cc)!

推荐阅读

    excel怎么用乘法函数

    excel怎么用乘法函数,乘法,函数,哪个,excel乘法函数怎么用?1、首先用鼠标选中要计算的单元格。2、然后选中单元格后点击左上方工具栏的fx公

    wps如何修改页眉上边距

    wps如何修改页眉上边距,WPS教程,1.WPS版word怎样设置页眉边距WPS中word设置页眉边距技巧“页边距”:页面上打印区域之外的空白空间。1、设

    excel中乘法函数是什么?

    excel中乘法函数是什么?,乘法,函数,什么,打开表格,在C1单元格中输入“=A1*B1”乘法公式。以此类推到多个单元。1、A1*B1=C1的Excel乘法公式

    标准差excel用什么函数?

    标准差excel用什么函数?,函数,标准,什么,在数据单元格的下方输入l标准差公式函数公式“=STDEVPA(C2:C6)”。按下回车,求出标准公差值。详细

    修改电脑系统信息|电脑更改系统

    修改电脑系统信息|电脑更改系统,,电脑更改系统重命名步骤如下:1、首先,点击桌面左下角的”菜单“图标,然后点击”设置“进入设置页面。2、接