我可能有一個小問題。即當我使用“post.comments.all”時如何提取最后一條評論
class CommentPost(models.Model):
user = models.ForeignKey(Profil, on_delete=models.CASCADE)
post = models.ForeignKey(Posty, on_delete=models.CASCADE, related_name="comments")
content1 = models.TextField(max_length=250, blank=False, null=False)
date_posted = models.DateTimeField(default=timezone.now)
date_updated = models.DateTimeField(auto_now=True)
def __str__(self):
return str(self.content1)
class Posty(models.Model):
title = models.CharField(max_length=250, blank=False, null=False, unique=True)
sub_title = models.SlugField(max_length=250, blank=False, null=False, unique=True)
content = models.TextField(max_length=250, blank=False, null=False)
image = models.ImageField(default="avatar.png",upload_to="images", validators=[FileExtensionValidator(['png','jpg','jpeg'])])
author = models.ForeignKey(Profil, on_delete=models.CASCADE)
updated = models.DateTimeField(auto_now=True)
published = models.DateTimeField(auto_now_add=True)
T_or_F = models.BooleanField(default=False)
likes = models.ManyToManyField(Profil, related_name='liked')
unlikes = models.ManyToManyField(Profil, related_name='unlikes')
created_tags = models.ForeignKey('Tags', blank=True, null=True, related_name='tagi', on_delete=models.CASCADE)
觀看次數
tag = request.GET.get('tag')
if tag == None:
my_tag = Posty.objects.all
print(my_tag)
else:
my_tag = Posty.objects.filter(created_tags__tag=tag)
print(my_tag)
如果我嘗試使用 '[:1]' 或 last,這不起作用。

uj5u.com熱心網友回復:
您可以通過以下方式獲得最后一條評論:
post.comments.latest('date_posted')
或者如果你想要最新的 per date_updated,你可以使用:
post.comments.latest('date_updated')
如果你想獲得每篇文章的最后一條評論,你可以使用一個Prefetch物件:
from django.db.models import OuterRef, Subquery
posts = Posty.objects.annotate(
latest_comment=Subquery(
CommentPost.objects.filter(
post=OuterRef('pk')
).values('content1').order_by('-date_posted')[:1]
)
)
然后在模板中,您可以使用以下命令進行渲染:
{% for post in posts %}
{{ post.last_comment }}
{% endfor %}
轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/397245.html
