您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python – django – 在查询集上切片/过滤后过滤,结果有限

5b51 2022/1/14 8:22:12 python 字数 1977 阅读 525 来源 www.jb51.cc/python

难以理解为什么我无法在查询集上切片后进行过滤以及发生了什么. stuff = stuff.objects.all() stuff.count() = 7 如果我然后去 extra_stuff = stuff.filter(stuff_flag=id) extra_stuff.count() = 6.一切都很好,我的新查询集在extrastuff没有问题 stuff = stuff.objects.

概述

stuff = stuff.objects.all()
stuff.count()

= 7

如果我然后去

extra_stuff = stuff.filter(stuff_flag=id)
extra_stuff.count()

= 6.一切都很好,我的新查询集在extrastuff没有问题

stuff = stuff.objects.all()[:3]
extra_stuff = stuff.filter(stuff_flag=id)

我收到错误“切片一旦切片就无法过滤查询”.

如何在我限制结果数量查询集中进一步过滤?

Cannot filter a query once a slice has been taken.

你可以用Python做过滤器

stuff = stuff.objects.all()[:3]
extra_stuff = [s for s in stuff if s.stuff_flag=='flag']

获取extra_stuff中的数字或项目,只需使用len()

extra_stuff_count = len(extra_stuff)

当东西的大小非常小时,在Python中进行过滤可以正常工作,就像在这种情况下一样.如果你有一个更大的切片,你可以使用子查询,但是这也可能有性能问题,你必须测试.

extra_stuff = Stuff.objects.filter(id__in=stuff,stuff_flag='flag')

总结

以上是编程之家为你收集整理的python – django – 在查询集上切片/过滤后过滤,结果有限全部内容,希望文章能够帮你解决python – django – 在查询集上切片/过滤后过滤,结果有限所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶