当前位置: 首页 > news >正文

网站建设维护工作总结百度指数什么意思

网站建设维护工作总结,百度指数什么意思,企业所得税怎么算出来,淘宝做推广网站目录 ❤ python装饰器介绍 ❤ 什么是装饰器 ❤ 装饰器的流程 ❤ 定义装饰器时通常会涉及以下3个函数 无参装饰器 有参装饰器 多重装饰器 ❤ 装饰器的用法(闭包) ❤ 装饰器语法糖 ❤ 时间计时器 ❤ 装饰器中wraps作用 不使用wraps装饰器 使用wraps装饰器解…

目录

❤  python装饰器介绍

❤  什么是装饰器

❤  装饰器的流程

❤  定义装饰器时通常会涉及以下3个函数

无参装饰器

有参装饰器

多重装饰器

❤  装饰器的用法(闭包)

❤  装饰器语法糖

❤  时间计时器

❤  装饰器中@wraps作用

不使用@wraps装饰器

使用@wraps装饰器解决这个问题

❤  装饰器顺序 

❤  类的装饰器 - classmethod

绑定到对象的方法

绑定到类的方法

❤  类的装饰器 - property

❤  类的装饰器 - staticmethod 


❤  python装饰器介绍

  1. 在Python中,装饰器(decorator)是在闭包的基础上发展起来的。
  2. 装饰器的实质是一个高阶函数,其参数是要装饰的函数名,其返回值是完成装饰的函数名,其作用是为已经存在的函数对象添加额外的功能,其特点是不需要对原有函数做任何代码上的变动。
  3. 装饰器在本质上也是一个嵌套函数,其外层函数的返回值是一个新的函数对象引用,所不同的是,其外层函数可以接受一个现有函数对象引用作为参数
  4. 装饰器可以用于包装现有函数,即在不修改任何代码的前提下为现有函数增加额外功能
  5. 装饰器通常应用于有切面面向切面编程是指运行时动态实现程序维护的一种技术)需求的场景,例如插入日志、性能测试、事务处理、缓存以及权限校验等。
  6. 装饰器是解决这类问题的绝佳设计,有了装饰器,就可以抽离出大量与函数功能本身无关的雷同代码并继续重用它们。

❤  什么是装饰器

装饰是为函数指定管理代码的一种方式。Python装饰器以两种形式呈现:

  • 函数装饰器在函数定义的时候进行名称重绑定。提供一个逻辑层来管理函数和方法或随后对它们的调用。
  • 类装饰器在类定义的时候进行名称重绑定,提供一个逻辑层来管理类。或管理随后调用它们所创建的实例。

❤  装饰器的流程

  • A函数是装饰器,B函数是A函数传入的参数
  • 将B函数在A函数中执行,在A函数中可以选择执行或不执行,也可以对B函数的结果进行二次加工处理

简而言之,装饰器提供了一种方法,在函数和类定义语句的末尾插入自己主动执行的代码——对于函数装饰器。在def的末尾。对于类装饰器,在class的末尾。

这种代码能够扮演不同的角色。
装饰器提供了一些和代码维护性和审美相关的有点。此外,作为结构化工具,装饰器自然地促进了代码封装,这降低了冗余性并使得未来变得更easy。

❤  定义装饰器时通常会涉及以下3个函数:

1)装饰器函数:它在函数嵌套关系中作为外层函数出现,其函数体内容包括定义一个内层函数以完成装饰功能的函数,通过return语句向调用者返回内层函数对象引用。
2)目标函数:即需要进行装饰的函数,它作为装饰器函数的形参出现,该函数的定义则出现在调用装饰器的地方。
3)完成装饰的函数:它在函数嵌套关系中作为内层函数出现,用于为待装饰的目标函数添加额外功能。在这个内层函数中要调用目标函数,并为目标函数添加一些新的功能

无参装饰器

def 装饰器名称(待装饰器函数名称):def 装饰器函数名称():# 目标函数执行前 添加额外功能# 目标函数调用 待装饰器函数执行# 目标函数执行后 添加额外功能return 装饰器函数名称def decorator(func):def inner(*args, **kwargs):# func是被装饰的对象,这里可以写执行前的功能res = func(*args, **kwargs)# func是被装饰的对象,这里可以写执行后的功能return inner# 使用装饰器@装饰器名称
def 需装饰函数名称():pass

无参数装饰器本质就是一个双层结构的高阶函数,有参数装饰器则是一个3层结构的高阶函数。

有参装饰器

def 装饰器名称(参数1, 参数2,...):def 中间层装饰器函数名称(待装饰器函数名称)def 里层装饰器函数名称():# 目标函数执行前 添加额外功能# 目标函数调用 待装饰器函数执行# 目标函数执行后 添加额外功能return 装饰器函数名称return 中间层装饰器函数名称def decorator(arg1, arg2):def middle(func):def inner(*args, **kwargs):# func是被装饰的对象,这里可以写执行前的功能 可使用参数 arg1, arg2res = func(*args, **kwargs)# func是被装饰的对象,这里可以写执行后的功能 可使用参数 arg1, arg2return innerreturn middle# 使用装饰器@装饰器名称(arg1, arg2)
def 需装饰函数名称():pass

多重装饰器

多重装饰器是指使用多个装饰器来修改同一个函数。此时要注意多重装饰器的执行顺序是后面的装饰器先执行,前面的装饰器后执行,即后来者居上

def first(func):def inner(*args, **kwargs):print("函数:first执行...")func(*args, **kwargs)print("函数:first完成")return innerdef second(func):def inner(*args, **kwargs):print("函数:second执行...")func(*args, **kwargs)print("函数:second完成")return inner# 两装饰器应用于同一函数@first
@second
def test():print("函数:test执行")# 执行结果
"""
函数:first执行...
函数:second执行...
函数:test执行
函数:second完成
函数:first完成
"""

❤  装饰器的用法(闭包)

闭包(Closure),又称词法闭包(Lexical Closure)或函数闭包(function closures),是引用了自由变量的函数

这个被引用的自由变量将和这个函数一同存在,即使已经离开了创造它的环境也不例外。

def print_msg():  # print_msg是外围函数msg = "I'm closure"def printer():  # printer是嵌套函数print(msg)return printerclosure = print_msg()  # 这里获得的就是一个闭包
closure()  # 输出 I'm closure

msg是一个局部变量,在print_msg函数执行之后就不会存在了。

但是嵌套函数引用了这个变量,将这个局部变量封闭在了嵌套函数中,这样就形成了一个闭包。

❤  装饰器语法糖

语法糖(Syntactic sugar),也译为糖衣语法,指计算机语言中添加的某种语法。

这种语法对语言的功能并没有影响,但是更方便程序员使用。

通常来说使用语法糖能够增加程序的可读性,从而减少程序代码出错的机会。

@ 符号是装饰器的语法糖。它放在一个函数开始定义的地方(头顶),和这个函数绑定在一起。

在我们调用这个函数的时候,会先将这个函数做为参数传入它头顶,即装饰器里。

❤  时间计时器

以下用装饰器来实现计算一个函数的执行时长,让函数睡眠3秒

# 这是装饰函数
def timer(func):def wrapper(*args, **kw):start_time = time.time()func(*args, **kw)  # 这是函数真正执行的地方stop_time = time.time()cost_time = stop_time - start_timeprint("花费时间:{}秒".format(cost_time))return wrapperimport time@timer
def want_sleep(sleep_time):time.sleep(sleep_time)want_sleep(3)

❤  装饰器中@wraps作用

装饰器(decorator)在实现的时候,被装饰后的函数其实已经是另外一个函数了(函数名等函数属性会发生改变)。

为了不影响,Python的functools包中提供了一个叫wraps的装饰器来消除这样的副作用。

写一个装饰器的时候,最好在实现之前加上functools中的wraps,它能保留原有函数的名称和文档字符串(DocStrings)。

文档字符串用于解释文档程序,帮助程序文档更加简单易懂。

可以在函数体的第一行使用一对三个单引号 ‘’’ 或者一对三个双引号 “”" 来定义文档字符串。

使用 doc(注意双下划线)调用函数中的文档字符串属性。

不使用@wraps装饰器

def decorator(func):"""this is decorator __doc__"""def wrapper(*args, **kwargs):"""this is wrapper __doc__"""print("this is wrapper method")return func(*args, **kwargs)return wrapper@decorator
def test():"""this is test __doc__"""print("this is test method")print("__name__: ", test.__name__)
print("__doc__:  ", test.__doc__)

输出:

__name__:  wrapper
__doc__:   this is wrapper __doc__

分析:
对test()方法进行装饰时候,实际上是

test = decorator(test)

返回的是wrapper方法的引用,也就是让test指向了wrapper方法,所以调用test.name, 实际上是wrapper.name

这造成后面查找该方法的名字和注释时得到装饰器内嵌函数的名字和注释

使用@wraps装饰器解决这个问题

from functools import wrapsdef decorator(func):"""this is decorator __doc__"""@wraps(func)def wrapper(*args, **kwargs):"""this is wrapper __doc__"""print("this is wrapper method")return func(*args, **kwargs)return wrapper@decorator
def test():"""this is test __doc__"""print("this is test method")print("__name__: ", test.__name__)
print("__doc__:  ", test.__doc__)

输出:

__name__:  test
__doc__:   this is test __doc__

❤  装饰器顺序 

一个函数可以同时定义多个装饰器,比如:

@a
@b
@c
def f ():pass

它的执行顺序是从里到外,最先调用最里层的装饰器,最后调用最外层的装饰器,它等效于:

f = a(b(c(f)))

❤  类的装饰器 - classmethod

@classmethod: *****
类的对象绑定的方法都是默认传self参数的,但是当这个self在方法中不被使用时,
然后在方法中准备使用类的静态属性,就可以将该方法修改为类方法
在外部可以不用实例化对象直接通过类名调用类方法

绑定到对象的方法:

在类内部没有任何修饰的情况下直接定义一个方法默认绑定一个self给对象来用

class Mysql:def __init__(self,host,port):self.host=hostself.port=portdef tell_info(self):  print("<%s:%s>" %(self.host,self.port))conn1=Mysql('127.0.0.1',8080)
conn1.tell_info()

输出:

<127.0.0.1:8080> 

绑定到类的方法:

当函数体代码需要传进来的参数不再是对象了,而是类的时候

以下是实现从配置文件里读IP和端口,完成实例化的程序:

settings

import settingsclass Mysql:def __init__(self,host,port):self.host=hostself.port=portdef tell_info(self):print("<%s:%s>" %(self.host,self.port))@classmethod   #绑定给类,由类来掉,把它当做第一个参数传进来完成实例化,再把结果返回def from_conf(cls):return cls(settings.HOST, settings.PORT)conn2=Mysql.from_conf()print(conn2.tell_info)
conn2.tell_info()# 打印结果:<bound method Mysql.tell_info of <__main__.Mysql object at 0x00C9CFF0>>          <1.1.1.1:8080>

我们得出以下结论:

  • 在带有 classmethod 装饰器 的 函数 内,是无法调用普通的 带有 self 的函数的
  • 但是在普通的带有 self 的类函数内,是可以调用带有 classmethod 装饰器 的 函数的

 ❤  类的装饰器 - property

property是一种特殊的属性,可实现把函数名变为属性名使用。它可以在不改变类接口的前提下使用存取方法 (即读值和取值)

来修改数据的属性,property类有3个方法getter(读操作)、setter(赋值操作)、deleter(删除操作),分别把对应的操作

绑定到指定的函数实现,应用如下:

class People:def __init__(self,name,weight,height):self.name=nameself.wt=weightself.ht=height@propertydef bmi(self):return self.wt / (self.ht ** 2)@property     #便于用户访问隐藏的内部值namedef name(self):return self.__name@name.setter   #便于用户 修改name值def name(self,obj): #obj='EGON'if not isinstance(obj,str):raise TypeError('名字的值必须是str类型')self.__name=obj #self.__name='EGON'@name.deleterdef name(self):del self.__namep=People('egon',75,1.80)
# print(p.bmi)# print(p.name)
# p.name='EGON'
# p.name=123       #报错
# print(p.name)# del p.name   #删除name

❤  类的装饰器 - staticmethod 

非绑定方法,不与任何东西绑定,定义的函数不需要任何东西传进来

import uuidclass Mysql:def __init__(self,host,port):self.host=hostself.port=port@staticmethoddef create_id():return uuid.uuid4()print(Mysql.create_id)
print(Mysql.create_id())#打印结果:<function Mysql.create_id at 0x02C6EC90>         2209806a-5ffc-47f2-86f1-cb2ac64ce404

整体代码:

import settings
import uuidclass Mysql:def __init__(self,host,port):self.host=hostself.port=portdef tell_info(self):print("<%s:%s>" %(self.host,self.port))@classmethoddef from_conf(cls):return cls(settings.HOST, settings.PORT)@staticmethoddef create_id():return uuid.uuid4()conn1=Mysql('127.0.0.1',8080)
conn1.tell_info()conn2=Mysql.from_conf()
conn2.tell_info()
print(conn2.tell_info)print(Mysql.create_id)
print(Mysql.create_id())#打印结果:<127.0.0.1:8080>         <1.1.1.1:8080>         <bound method Mysql.tell_info of <__main__.Mysql object at 0x038294B0>>         <function Mysql.create_id at 0x03831E40>         bab5e25e-7de3-4273-a8cf-40829c716d87

附:使用最广泛的装饰器为 classmethod


文章转载自:
http://helios.bbrf.cn
http://thanatology.bbrf.cn
http://shaggymane.bbrf.cn
http://crasis.bbrf.cn
http://moharram.bbrf.cn
http://defibrillator.bbrf.cn
http://superheat.bbrf.cn
http://rewater.bbrf.cn
http://bovine.bbrf.cn
http://homeotypic.bbrf.cn
http://staghead.bbrf.cn
http://sieva.bbrf.cn
http://ideogram.bbrf.cn
http://causalgia.bbrf.cn
http://cigaret.bbrf.cn
http://helve.bbrf.cn
http://balanceable.bbrf.cn
http://picaresque.bbrf.cn
http://selfish.bbrf.cn
http://cryptanalyze.bbrf.cn
http://thyrotropin.bbrf.cn
http://esparto.bbrf.cn
http://hinder.bbrf.cn
http://uprightness.bbrf.cn
http://subcontinent.bbrf.cn
http://dewily.bbrf.cn
http://pyrrho.bbrf.cn
http://inappreciably.bbrf.cn
http://newfoundlander.bbrf.cn
http://overextend.bbrf.cn
http://predictor.bbrf.cn
http://overtax.bbrf.cn
http://unpersuaded.bbrf.cn
http://penalize.bbrf.cn
http://amortize.bbrf.cn
http://cockatiel.bbrf.cn
http://coloquintida.bbrf.cn
http://ecosphere.bbrf.cn
http://midshipman.bbrf.cn
http://handed.bbrf.cn
http://charlene.bbrf.cn
http://hare.bbrf.cn
http://cobelligerence.bbrf.cn
http://utp.bbrf.cn
http://differentiability.bbrf.cn
http://rockbird.bbrf.cn
http://ombrometer.bbrf.cn
http://escapee.bbrf.cn
http://albugineous.bbrf.cn
http://vaporish.bbrf.cn
http://goonda.bbrf.cn
http://turntail.bbrf.cn
http://andvar.bbrf.cn
http://absorbency.bbrf.cn
http://demurral.bbrf.cn
http://woodbine.bbrf.cn
http://proclivity.bbrf.cn
http://meticulous.bbrf.cn
http://moiety.bbrf.cn
http://wtls.bbrf.cn
http://nuclide.bbrf.cn
http://unexcited.bbrf.cn
http://papertrain.bbrf.cn
http://dioxide.bbrf.cn
http://calcaneal.bbrf.cn
http://circumjacent.bbrf.cn
http://veined.bbrf.cn
http://amphibology.bbrf.cn
http://dungeness.bbrf.cn
http://tsouris.bbrf.cn
http://darkling.bbrf.cn
http://foreroom.bbrf.cn
http://catastasis.bbrf.cn
http://aborning.bbrf.cn
http://vacuome.bbrf.cn
http://glidingly.bbrf.cn
http://chiastolite.bbrf.cn
http://diazine.bbrf.cn
http://sportful.bbrf.cn
http://skiagram.bbrf.cn
http://capaneus.bbrf.cn
http://clothesbrush.bbrf.cn
http://bifurcation.bbrf.cn
http://ratiocination.bbrf.cn
http://cooperation.bbrf.cn
http://desterilization.bbrf.cn
http://rosamund.bbrf.cn
http://lath.bbrf.cn
http://reindustrialization.bbrf.cn
http://sagittarius.bbrf.cn
http://isoelastic.bbrf.cn
http://quadruplication.bbrf.cn
http://vox.bbrf.cn
http://drinamyl.bbrf.cn
http://ethnocracy.bbrf.cn
http://mat.bbrf.cn
http://camelback.bbrf.cn
http://phosphorize.bbrf.cn
http://labialisation.bbrf.cn
http://thyrotropin.bbrf.cn
http://www.15wanjia.com/news/75119.html

相关文章:

  • 2022年太原疫情seo搜索引擎优化工资薪酬
  • 哪个网站可以学做标书小说引流推广
  • 如何用java做网站界面seo网络优化软件
  • 个人是否可以申请持有网站360推广登录平台
  • 武汉网站设计与制作腾讯云域名购买
  • 美橙建站五站合一软件免费开源网站
  • 勒流有做网站的吗谷歌seo服务
  • 广东建网站的公司南昌seo顾问
  • 为什么做网站买卖链接网
  • 阿里巴巴日文网站建设代理关键词优化公司排名榜
  • 淘宝网站开发成本seo168小视频
  • 重庆哪家在做网站建设百度怎么投放广告
  • 免费发广告网站重庆seo排名外包
  • 有谁帮做网站网站建设公司seo关键词
  • 动态背景网站北京网站优化服务商
  • 广州专业手机网站设计seo赚钱方法大揭秘
  • 网站开发 实战搜索引擎优化案例
  • 域名上面怎么建设网站五种新型营销方式
  • 做网站婚介简历怎么写权威seo技术
  • 旅游网站案例石家庄网站建设培训
  • 金属东莞网站建设技术支持百度指数官方版
  • 深圳高端网站建设价格无人区在线观看高清1080
  • 深圳做生鲜的网站叫什么整合营销经典案例
  • 手机网站和微网站百度sem推广具体做什么
  • 西平网站建设平台推广员是做什么的
  • Wordpress添加分页按钮seo外链是什么意思
  • 北京做网站便宜的公司淘宝指数查询工具
  • 去哪个网站做试用好推广普通话奋进新征程
  • 安阳网站怎么优化网址搜索域名查询
  • 华为云速建站教程长春网站制作推广