在django admin中加入两个表以获取display_list的列

时间:2018-09-22 06:59:48

标签: django python-3.x django-admin

我在使用django管理界面的list_display / joining两个表时遇到问题。

我希望具有 SchPrograms 模型中的 program_name is_active 列,其中 parameter_name,parameter_description Django管理员中的> VisVisitParameters 模型。我能够在这些模型的每一个中都有与return一起使用的那些列。我试图从已经被要求的question那里寻求帮助。但是我仍然无法弄清楚这一点。

class SchPrograms(models.Model):
  program_id = models.AutoField(primary_key=True)
  program_name = models.CharField(max_length=200, blank=True, null=True)
  creation_timestamp = models.DateTimeField(blank=True, null=True)
  is_active = models.IntegerField()

  class Meta:
      managed = True
      db_table = 'sch_programs'
      app_label = 'polls'

  def __str__(self):
      return self.program_name

class VisVisitParameters(models.Model):
   vparameter_id = models.AutoField(primary_key=True)
   parameter_name = models.CharField(max_length=300, blank=True, null=True)
   parameter_description = models.TextField(blank=True, null=True)
   is_active = models.IntegerField(choices=STATUS_CHOICES)

   class Meta:
       managed = False
       db_table = 'vis_visit_parameters'

   def __str__(self):
       return str(self.vparameter_id)
       app_label = 'polls'


class VisVisitParameterMappings(models.Model):
    vp_map_id = models.AutoField(primary_key=True)
    vparameter =  models.ForeignKey(VisVisitParameters,on_delete=models.CASCADE)
    program = models.ForeignKey(SchPrograms,on_delete=models.CASCADE)
    display_order = models.IntegerField(blank=True, null=True)
    is_active = models.IntegerField()

    class Meta:
       managed = False
       db_table = 'vis_visit_parameter_mappings'
       app_label = 'polls'

    def __str__(self):
       return str(self.parameter_name)

model.py

class VisVisitParameterMappings_admin(admin.ModelAdmin):
    list_display =   ('program_name','is_active','parameter_name','parameter_description ')

1 个答案:

答案 0 :(得分:2)

要在列表显示页面上显示必需的项目,您可以编写here中所述的自定义方法。

例如,对于名为 program_name 的字段,您可以拥有:

def program_name(self, obj):
    if obj.program:
        return obj.program.program_name

program_name.short_description = 'Program name'

,对于其他名为 parameter_name 的模型字段,您可能具有:

def parameter_name(self, obj):
    if obj.vparameter:
        return obj.vparameter.parameter_name

parameter_name.short_description = 'Parameter Name'

希望有帮助。