Я разработал собственный класс менеджера с цепным методом.Есть проблема.Мне нужно рандомизировать фильтрованный запрос.Чтобы получить случайную запись, мне нужно количество отфильтрованных и отдельных записей.Но я не знаю, как это получить.Напротив, у меня есть счетчик всех записей.
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