Django:我想按最后评论/更新对帖子进行排序
Django: I want to sort posts by last comment / update
我在学习教程后编写了一个简单的博客,到目前为止它可以正常工作。
但现在我想按 post 中的最后一个 activity 对 post 列表进行排序。一旦发布了新的 post 或批准了新的评论,post 就应该位于列表的顶部。 (它在论坛中的工作方式..)
这是我目前所拥有的...
(似乎按 "updated_date" 排序列表有效,但在批准评论时附加正确的日期时间失败。)
提前感谢您的帮助
models.py
class Post(models.Model):
author = models.ForeignKey('auth.User', on_delete=models.DO_NOTHING,)
title = models.CharField(max_length=200)
text = RichTextUploadingField()
created_date = models.DateTimeField(default=timezone.now)
published_date = models.DateTimeField(blank=True, null=True)
updated_date = models.DateTimeField(blank=True, null=True)
def publish(self):
self.published_date = timezone.now()
self.save()
def __str__(self):
return self.title
class Comment(models.Model):
post = models.ForeignKey('blog.Post', related_name='comments', on_delete=models.DO_NOTHING,)
author = models.CharField(max_length=200)
text = models.TextField()
created_date = models.DateTimeField(default=timezone.now)
approved_comment = models.BooleanField(default=False)
def approve(self):
self.approved_comment = True
Post.updated_date = timezone.now()
self.save()
def __str__(self):
return self.text
def approved_comments(self):
return self.comments.filter(approved_comment=True)
views.py
def post_list(request):
posts = post.objects.filter(updated_date__lte=timezone.now()).order_by('-updated_date')
return render(request, 'blog/post_list.html', {'posts': posts})
blog.views.post_detail
@login_required
def post_publish(request, pk):
post = get_object_or_404(Post, pk=pk)
post.publish()
return redirect('post_detail', pk=pk)
def add_comment_to_post(request, pk):
post = get_object_or_404(Post, pk=pk)
if request.method == "POST":
form = CommentForm(request.POST)
if form.is_valid():
comment = form.save(commit=False)
comment.post = post
comment.save()
return redirect('post_detail', pk=post.pk)
else:
form = CommentForm()
return render(request, 'blog/add_comment_to_post.html', {'form': form})
@login_required
def comment_approve(request, pk):
comment = get_object_or_404(Comment, pk=pk)
comment.approve()
return redirect('post_detail', pk=comment.post.pk)
你可以这样尝试 aggregation:
from django.db.models import Max
Post.objects.filter(comments__approved_comment=True).annotate(max_activity=Max('comments__created_date')).order_by('max_activity', 'updated_date')
仅供参考 approved_comments
和 Comment
模型 class 中的 approve
方法将不起作用。他们应该是这样的:
def approved_comments(self):
return self.__class__.objects.filter(approved_comment=True)
def approve(self):
self.approved_comment = True
self.post.updated_date = timezone.now()
self.post.save()
self.save()
在 Comment.approve()
中,您将 updated_date
附加到 Post
的 class 而不是与评论相关的实例。更新日期时应使用 self.post
:
def approve(self):
self.approved_comment = True
self.post.updated_date = timezone.now()
self.save()
我在学习教程后编写了一个简单的博客,到目前为止它可以正常工作。 但现在我想按 post 中的最后一个 activity 对 post 列表进行排序。一旦发布了新的 post 或批准了新的评论,post 就应该位于列表的顶部。 (它在论坛中的工作方式..)
这是我目前所拥有的... (似乎按 "updated_date" 排序列表有效,但在批准评论时附加正确的日期时间失败。)
提前感谢您的帮助
models.py
class Post(models.Model):
author = models.ForeignKey('auth.User', on_delete=models.DO_NOTHING,)
title = models.CharField(max_length=200)
text = RichTextUploadingField()
created_date = models.DateTimeField(default=timezone.now)
published_date = models.DateTimeField(blank=True, null=True)
updated_date = models.DateTimeField(blank=True, null=True)
def publish(self):
self.published_date = timezone.now()
self.save()
def __str__(self):
return self.title
class Comment(models.Model):
post = models.ForeignKey('blog.Post', related_name='comments', on_delete=models.DO_NOTHING,)
author = models.CharField(max_length=200)
text = models.TextField()
created_date = models.DateTimeField(default=timezone.now)
approved_comment = models.BooleanField(default=False)
def approve(self):
self.approved_comment = True
Post.updated_date = timezone.now()
self.save()
def __str__(self):
return self.text
def approved_comments(self):
return self.comments.filter(approved_comment=True)
views.py
def post_list(request):
posts = post.objects.filter(updated_date__lte=timezone.now()).order_by('-updated_date')
return render(request, 'blog/post_list.html', {'posts': posts})
blog.views.post_detail
@login_required
def post_publish(request, pk):
post = get_object_or_404(Post, pk=pk)
post.publish()
return redirect('post_detail', pk=pk)
def add_comment_to_post(request, pk):
post = get_object_or_404(Post, pk=pk)
if request.method == "POST":
form = CommentForm(request.POST)
if form.is_valid():
comment = form.save(commit=False)
comment.post = post
comment.save()
return redirect('post_detail', pk=post.pk)
else:
form = CommentForm()
return render(request, 'blog/add_comment_to_post.html', {'form': form})
@login_required
def comment_approve(request, pk):
comment = get_object_or_404(Comment, pk=pk)
comment.approve()
return redirect('post_detail', pk=comment.post.pk)
你可以这样尝试 aggregation:
from django.db.models import Max
Post.objects.filter(comments__approved_comment=True).annotate(max_activity=Max('comments__created_date')).order_by('max_activity', 'updated_date')
仅供参考 approved_comments
和 Comment
模型 class 中的 approve
方法将不起作用。他们应该是这样的:
def approved_comments(self):
return self.__class__.objects.filter(approved_comment=True)
def approve(self):
self.approved_comment = True
self.post.updated_date = timezone.now()
self.post.save()
self.save()
在 Comment.approve()
中,您将 updated_date
附加到 Post
的 class 而不是与评论相关的实例。更新日期时应使用 self.post
:
def approve(self):
self.approved_comment = True
self.post.updated_date = timezone.now()
self.save()