在
django应用程序中,我创建了不同的模型,一切看起来都不错,直到我尝试使用同一个表中两个不同模型的数据.
总结一下:在主页中,我需要创建一个包含两个模型的数据的表,按日期排序.
我需要显示的两个模型如下.
models.py
class Document(models.Model):
number = models.CharField(max_length=10)
description = models.CharField(max_length=50)
assigned = models.BooleanField
validity_date = models.DateField
is_issued = models.BooleanField
class Program(models.Model):
name = models.CharField(max_length=25)
description = models.CharField(max_length=100)
validity_date = models.DateField
然后,我尝试创建一个允许我使用不同模型的视图.
这是我的view.py:
class BaseView(generic.ListView):
template_name = 'base/base_list.html'
context_object_name = 'base_list'
def get_queryset(self):
queryset = Document.objects.order_by('due_date')
return queryset
def get_context_data(self, **kwargs):
context = super(BaseView, self).get_context_data(**kwargs)
context['Programs'] = Program.objects.all()
context['Employees'] = Employee.objects.all()
return context
现在,我如何在模板内部创建一个表格,同时显示两个模型,按有效日期排序每个条目(无论条目属于程序还是文档)?
先感谢您!
最佳答案 您需要首先查询两个模型,将它们链接在一起(连接它们),然后按其共享属性(即validity_date)进行排序.你可以这样做:
from itertools import chain
documents = Documents.objects.all()
programs = Program.objects.all()
final_combined_list = sorted(chain(documents,programs),key=lambda instance: instance.validity_date)
您现在可以简单地将final_combine_list传递给模板并渲染它以您想要的方式显示它.
希望这可以帮助!