繁体   English   中英

如何以随机方式订购我的对象?

[英]How do I order my objects in a random way?

我在 Python 3.7 和 PostGres 9.5 中使用 Django。 我使用以下内容来获取我所有的对象并迭代它们......

article_set = Article.objects.all()
for article in article_set:

有没有办法修改我现有的查询或可能的循环,以便每次都以随机顺序返回对象? 如果可能的话,我宁愿不进行第二次查询。

正如文档中所解释的,您可以使用order_by('?')如下:

article_set = Article.objects.order_by('?')

我对 Django 不太熟悉,如果我错了,请纠正我,但我认为:

Article.objects.all()
#Roughly equates to:
"SELECT * from articles"

所以我相信你应该能够做到:

Article.objects.all().order_by('RANDOM()')
#Thus producing this SQL statement:
"SELECT * from articles ORDER BY RANDOM()"

这应该混淆你的输出。


否则,我会说使用random.shuffle方法。

from random import shuffle

article_set = Article.objects.all()
for article in shuffle(article_set):
    #do work

让我知道 order_by 是否有效,我可以相应地进行编辑。 就像我说的,我对 Django 不太熟悉,所以这是未经测试的,但理论上应该可行。 谢谢!

做一个这样的循环

article_set = Article.objects.all()
for article in random.shuffle(article_set):
    print(article)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM