1

我用可链接的方法开发了一个自定义管理器类。有问题。我需要随机化过滤的查询。要获得随机记录,我需要计数过滤和不同的记录。但我不知道如何得到它。相反,我对所有记录进行了计数。

class RandomQueryset(models.query.QuerySet):

    def randomize(self):        
        count = self.aggregate(count=Count('id'))['count']
        random_index = random.randint(0, count - 1)
        return self.all()[random_index]    


class RandomManager(models.Manager):

    def get_query_set(self):
        return RandomQueryset(self.model, using=self._db)

    def randomize(self):
        return self.get_query_set().randomize()

使用:

>>> posts = PostPages.random_objects.filter(image_gallery__isnull=False).distinct()

>>> posts.randomize()

迟早我会收到一个错误,因为该计数超过了当前查询中的记录数。

IndexError: list index out of range
4

1 回答 1

1

你让我发布我的一个问题作为答案,所以就这样吧。

这看起来你需要使用 Django 的内置 count() 函数docs.djangoproject.com/en/dev/ref/models/querysets

我看不到它在您的代码中的用途。

于 2011-09-22T22:23:33.803 回答