Django 查询集的自定义过滤器

Custom filter for Django querysets

美好的一天,我有一个问题:我有一个包含一些字段的模型。

class Gallery(models.Model):
    image = models.FileField(upload_to='gallery/')
    status = models.BooleanField()
    type = models.BooleanField()

我使用此模型在砖石网格中存储图库图像。这个网格是固定的,我需要得到 12 个随机图像,这很容易做到。

gallery = Gallery.objects.all().order_by('id','pk').order_by('?')[: 12];

但是其中 5 个应该是 True 类型,另外 7 个是 False。如果它能够在此查询集中自定义顺序,我将非常高兴,例如,True 表示水平图片 (h),False - 垂直 [v]。我想要这样的订单 [v,h,h,h,v,v,v,h,h,v,v,v]

您可以执行两个查询,一个用于水平对象,一个用于垂直对象。

horizontal = Gallery.objects.filter(type=True).order_by('?')[:7]
vertical = Gallery.objects.filter(type=False).order_by('?')[:5]

然后根据您的两个查询集构建列表

gallery = [verical[0]] + horizontal[0:3] + vertical[1:4] + horizontal[3:] + vertical[4:]

请注意,例如 order_by docs warn that order_by('?') may be slow. If you hit performance problems, you might want to look for an alternative approach. See this question