python – django – 在查询集上切片/过滤后过滤,结果有限
发布时间:2020-12-16 22:58:57 所属栏目:Python 来源:网络整理
导读:难以理解为什么我无法在查询集上切片后进行过滤以及发生了什么. stuff = stuff.objects.all()stuff.count() = 7 如果我然后去 extra_stuff = stuff.filter(stuff_flag=id)extra_stuff.count() = 6.一切都很好,我的新查询集在extrastuff没有问题 stuff = stuf
难以理解为什么我无法在查询集上切片后进行过滤以及发生了什么.
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) 我收到错误“切片一旦切片就无法过滤查询”. 如何在我限制结果数量的查询集中进一步过滤? 解决方法
切片查询集后,不能使用filter().错误非常明确.
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') (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- Python3 加密(hashlib和hmac)模块的实现
- 是opencv python2包装中的getPerspectiveTransform破坏?
- 寻求有关如何防止Python中无情的“NameErrors”的一般建议
- python – 如何在Linux上打包Kivy IOS应用程序?
- 无论你是小白还是萌新!这篇都能教会你爬取网易云付费音乐!
- (信贷风控十四)深度神经网络模型用于评分卡模型(理论)
- 加权摇号(加权轮盘赌)算法
- Python信息抽取之乱码解决办法
- Python Sklearn – RandomForest和Missing值
- python – list comprehension,其中列表本身为None