Я объединил 2 набора запросов из разных моделей в список и использовал разбивку на страницы для отображения в виде единого списка.Django multiple queryset объединяется в разбивку на страницы
Проблема заключается в том, что объекты из списка отображаются в разбивке по страницам в соответствии с моделями, из которых они были созданы.
Как я мог исправить список таким образом, когда новый объект создается из моделей. Он будет отображаться после недавно созданного объекта, даже если последний созданный объект был из разных моделей.
Пример будет. У меня есть запрос на сборку пользовательской доски пользователя и комментарий пользователя. Если недавно был создан объект новой доски, и я бы создал еще один комментарий. Комментарий будет отображаться в пагинацией после объекта, досок «s вместо выставлялись со всеми другими комментариями далее вниз постраничным, потому что он был в разных моделях
Я надеюсь, что вы можете получить представление о том, что я пытаюсь достичь :)
Части моего модуля
class WhiteBoard(models.Model):
user = models.ForeignKey(User)
name = models.CharField(max_length=100)
created = models.DateTimeField(auto_now_add=True)
picture = models.OneToOneField('Picture',related_name='picture',blank=True,null=True)
def __unicode__(self):
return self.name
class Comment(models.Model):
created = models.DateTimeField(auto_now_add=True)
user = models.ForeignKey(User)
body = models.TextField()
picture = models.ForeignKey(Picture)
views.py
@login_required
def archive(request):
user = User.objects.get(username=request.user)
person = Person.objects.get(user=user)
users = User.objects.filter(pk__in=person.following.all().values_list('user__pk',flat=True))
picture = whiteboard .objects.filter(user__in=users).order_by("-created")
comment = Comment.objects.filter(user__in=users).order_by("-created")
posts= list(chain(picture,comment))
paginator = Paginator(posts, 5)
try: page = int(request.GET.get("page", '1'))
except ValueError: page = 1
try:
posts = paginator.page(page)
except (InvalidPage, EmptyPage):
posts = paginator.page(paginator.num_pages)
return render(request,'archive.html',{'picture':picture,'comment':comment,'posts':posts})
archive.html
{% for post in posts.object_list %}
{{post.name }}
<br>
{{post.body}}
{% endfor %}
<!-- Next/Prev page links -->
{% if posts.object_list and posts.paginator.num_pages > 1 %}
<div class="pagination" style="margin-top: 20px; margin-left: -20px; ">
<span class="step-links">
{% if posts.has_previous %}
<a href= "?page={{ posts.previous_page_number }}">newer entries << </a>
{% endif %}
<span class="current">
Page {{ posts.number }} of {{ posts.paginator.num_pages }}
</span>
{% if posts.has_next %}
<a href="?page={{ posts.next_page_number }}"> >> older entries</a>
{% endif %}
</span>
</div>
{% endif %}
</div>
@catherine Я просто отводом вокруг с the combination :) – donkeyboy72
@catherine Я пытаюсь добавить шрифт в корзину вашего сказанного, и я получил эту ошибку, не мог vert string to float: – donkeyboy72
Я не знаю, поможет ли это, он отсортировал данные. http://stackoverflow.com/questions/431628/how-to-combine-2-or-more-querysets-in-a-django-view – catherine