如何在同一个表中的同一个模板上显示来自两个不同django模型的实例?


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传递给模板并渲染它以您想要的方式显示它.

希望这可以帮助!

点赞