python魔法函数你不知道的秘密

视频链接https://zhuanlan.zhihu.com/p/562586782

什么是魔法函数?

是以双下划线开头和双下划线结尾命名的特殊函数,不需要开发者调用,由Python解释器调用。

可调用对象的概念:在python中,能够使用名称加()执行的对象都是可调用对象。

很显然所有的函数都是可调用对象,那么类实例对象是调用对象吗?

实验下:


报错了,错误信息提示Student对象不是一个可调用对象。

检测一个对象是否可调用还可以使用callable函数。


返回False,也说明了Student对象不是一个可调用对象。

那么这么才能拿让类实例对象变成可调用对象呢?

只要类实现了魔法函数__call__即可,我们试下。


很明显实现了__call__之后,Student对象变成了可调用对象;

其中__call__不需要要开发者来调用,它属于特殊函数,解释器会去调用的。

为什么要将了转化成可调用对象呢?哪些场景使用?

可调用对象,让类实例对象能够像函数一样接收参数,好处是更加简洁,不需要使用 对象.方法()。

使用场景:

1.在一些验证器中使用,举个例子:

import re

class PhoneValidator():

'''DEC:手机号格式合法验证器'''

def __call__(self, *args, **kwargs):

reg = '^1(3[0-9]|4[5,7]|5[0,1,2,3,5,6,7,8,9]|6[2,5,6,7]|7[0,1,7,8]|8[0-9]|9[1,8,9])d{8}#39;

phone = args[0]

if not re.match(reg, phone):

print("phone is validate.")

else:

print("phone is invalidate.")

phone_validator = PhoneValidator()

phone_validator("13735468254")

phone_validator("10735468254")

结果:

phone is invalidate.

phone is validate.

你可能会为那为什么不使用函数呢?类有更好的扩展性,你可能还需要做其他的事情呢?

所以我们需要的是函数但是又不仅仅只是函数。

2.在类装饰器中使用,在装饰器章节详细看下类装饰器。

'''

描述:虽然装饰器是用类实现的,但是最终用来替换原函数的对象,仍然是一个处在__call__方法里的闭包函数

'''

import time

import random

from functools import wraps

class Timer:

"""装饰器:打印函数的耗时

:param print_args:是否打印发发那个发名和参数,默认为False

"""

def __init__(self,print_args):

self.print_args = print_args

def __call__(self, func):

@wraps(func)

def decorated(*args, **kwargs):

'''

desc:jdhfksjdf

@param:args,

'''

st = time.perf_counter()

ret = func(*args, **kwargs)

if self.print_args:

print(f'"{func.__name__}",args:{args},kwargs:{kwargs}')

print("time cost:{} seconds".format(time.perf_counter()-st))

return ret

return decorated

@Timer(print_args=True)

def random_sleep():

print("random")

if __name__ == '__main__':

random_sleep()

展开阅读全文

页面更新:2024-03-20

标签:函数   魔法   下划线   扩展性   开发者   实例   场景   对象   参数   秘密   方法

1 2 3 4 5

上滑加载更多 ↓
推荐阅读:
友情链接:
更多:

本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828  

© CopyRight 2008-2024 All Rights Reserved. Powered By bs178.com 闽ICP备11008920号-3
闽公网安备35020302034844号

Top