python怎样做链式调用?有啥好处?
Admin 2021-05-22 群英技术资讯 504 次浏览
python链式调用如何实现?关于链式调用也就是调用完一个函数后还能再继续调用其它函数,这样的好处就是大大减少了代码量。那么在Python中如何实现链式调用呢?下面给大家分享一下实现方法。
我们在使用Django的models查询数据库时,可以看到有这种写法:
form app.models import XXX query = XXX.objects.all() query = query.filter(name=123, age=456).filter(salary=999)
在这种写法里面,query对象有一个filter
方法,这个方法的返回数据还可以继续调用filter
方法,可以这样无限制地调用下去。
这种写法是怎么实现的呢?
如果我们直接写一个类的方法,看看能不能这样调用:
class Query: def filter(self): pass query = Query() query.filter().filter()
直接对query.filter()
返回的结果再调用一次filter
,就会导致报错了。这是因为在没有显式写return语句的时候,方法会返回None
,而None对象是没有所谓的filter
方法的。
那么什么东西有filter方法呢?显然我们的query对象有filter方法。那么如何让这个方法返回自身这个对象呢?
这个时候,我们就要看看我们在定义类方法的时候,总会写的的第一个参数self
了。几乎每个类方法里面都会有它。大家只知道在类里面调用类方法的时候可以用self.xxx()
,在调用类属性的时候可以用self.yy
,那么有没有思考过,这个东西如果单独使用会怎么样呢?
实际上,self
指的就是这个类实例化成一个对象以后,这个对象自身。而这个对象显然是有filter
方法的。所以我们修改一下filter
方法,让它返回self
:
class Query: def filter(self): return self query = Query() query.filter().filter()
从图中可以看出,现在已经不会报错了。那么回到最开始的问题,Django里面的链式调用传入查询参数是如何实现的呢?
实际上这里涉及到一个惰性查询
的问题。
当我们不停调用.filter()
方法的时候,Django会把这些查询条件全部缓存起来,只有当我们需要获取结果,或者查询满足条件的数据有多少条时,它才会真正地连接数据库去查询。
所以我们这里要模拟这个环境,把查询条件缓存起来。
那么为了获取调用方法时传入的参数名,我们就要使用**kwargs
参数。这个参数可以接受所有的key=value形式的参数:
class Query(): def __init__(self): self.query_condition = {} def filter(self, **kwargs): self.query_condition.update(kwargs) return self query = Query() a = query.filter(name='kingname').filter(age__gt=15, address='yyyyyy').filter(salary=99999) print(query.query_condition)
运行效果如下图所示:
在真正需要输出结果的时候,再使用这些缓存的条件,去数据库中查询结果即可。
以上就是关于python实现链式调用的介绍了,现在大家对于python链式调用应该也有所了解了,上述示例有一定的借鉴价值,有需要的朋友可以参考学习,希望本文对大家有帮助。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家介绍了Pytorch卷积神经网络迁移学习的目标实现代码及好处介绍,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
这篇文章主要介绍了Python Http发送请求浅析,文章主要通过从requests、aiohttp、httpx三个接口请求展开详情,需要的朋友可以参考一下文章具体详细内容
这篇文章主要介绍了Python基础学习函数+模块+类,这是基础学习的第三篇内容,小编已把前两篇链接放在下面,需要学习的同学可以参考一下
这篇文章主要介绍了Python通过ffmpeg实现修改图片分辨率,文中的代码介绍详细,对我们的工作或学习有一定的价值,感兴趣的小伙伴可以学习一下
我们可以用python里面的time模块mktime方法将转为unix时间戳,mktime函数只能接受相应时间的元祖序列。在此之前需要先将输入的时间转为元组序列:如果输入的时间为指定格式的,则可以用strptime()函数根据指定的格式把一个时间字符串解析为时间元组,time.strptime(string[,format])例如:time.strptime('2017-11-181
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008