概述
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 – 在查询集上切片/过滤后过滤,结果有限所遇到的程序开发问题。
如果您也喜欢它,动动您的小指点个赞吧