Я создаю маленькое приложение для блога. Я хочу вернуть сообщение и (мою проблему) предыдущие и последующие сообщения, чтобы их можно было отображать вместе с сообщением. Мое текущее решение очень плохое, потому что я не только загружаю все объекты Post, но и конвертирую QuerySet в список. Вот фрагмент из views.py:
def post(request, url):
try:
post = Post.objects.get(slug = url)
except Post.DoesNotExist:
raise Http404()
posts = Post.objects.all().order_by('-date')
index = list(posts).index(post)
if index > 0:
ppost = posts[index - 1] #previuos post
else:
ppost = None
if index < len(posts):
npost = posts[index + 1] #next post
else:
npost = None
if not post.visible:
raise Http404()
return render_to_response('post.html',
{'post': post, 'ppost': ppost, 'npost': npost},
context_instance=RequestContext(request))
А вот models.py:
class Post(models.Model):
slug = models.SlugField(unique=True)
subject = models.CharField(max_length=150)
abstract = models.CharField(max_length=300)
content = models.TextField()
author = models.ForeignKey(User)
date = models.DateTimeField(auto_now_add=True)
visible = models.BooleanField(default=False)
tags = models.ManyToManyField(Tag, blank = True, null = True)
def save(self, *args, **kwargs):
self.abstract = self.content[:297] + "..."
self.slug = slugify(self.subject)
super(Post, self).save(*args, **kwargs)
def __unicode__(self):
return self.subject
class Meta:
ordering = ['-date']
Буду признателен за любые архитектурные идеи, как реализовать этот случай. Любые идеи на самом деле :). Заранее спасибо