我有一个Complaint
带有get_latest_response
方法的模型
class Complaint(models.Model):
message = models.TextField(blank=True)
email = models.CharField(max_length=255)
def get_latest_response(self):
return ResponseLetter.objects.filter(complaint=self)[:1][0]
方法get_latest_response
返回对此投诉的最新回复
和ResponseLetter
模型
class ResponseLetter(models.Model):
date_response = models.DateField(db_index=True)
response_content = models.TextField()
response_from = models.CharField(max_length=255)
complaint = models.ForeignKey(Complaint)
class Meta:
ordering = ["-date_response"]
然后在view
我收到投诉(queryset
)
complaints = Complaint.objects.all()
我必须订购complaints
这些 get_latest_response().date_response
但!我无法将其转换queryset
为list
喜欢
complaints = list(complaints)
complaints.sort(key=lambda x: x.get_latest_response().date_response)
因为在那之后我把它呈现queryset
在object_list
:
return object_list(request, template_name = 'complaint/complaints.html',
queryset = complaints, paginate_by = COMPLAINTS_PAGE_SIZE,
extra_context=extra_context
)
还有方法:
sorted(complaints, key=lambda a: a.get_latest_response().date_response)
也不行
你能给我什么建议吗?