如何在 Django Admin 中显示多对多模型中的所有字段

How can I display all fields from a Many-to-Many Model in Django Admin

我有以下型号:

class ModelA(models.Model):
    some_field_A = models.CharField()
    some_other_field_A = models.CharField()
    
class ModelB(models.Model):
    some_field_B = models.CharField()
    many_to_many_relation = models.ManyToManyField(ModelA)

admin.py 中,我正在使用 filter_horizontal 编辑 ManyToManyField:

class ModelB(admin.ModelAdmin):
    model = ModelB
    filter_horizontal = ('many_to_many_relation',)

但它只显示 some_field_A,我希望它显示 ModelA 的两个字段,因为 ModelA 中的条目根据两个字段是唯一的,并且正如您从图片中看到的那样,有多个条目带有相同的值(即 some_field_A = EUV)但它们具有不同的值 some_other_field_A:

我不确定这是否正是您正在寻找的解决方案,但您可以将 ModelA__str__ 方法覆盖为单行中的 return 信息。

例如:

class ModelA(models.Model):
  first_field = models.CharField(max_length=16)
  second_field = models.CharField(max_length=16)

  def __str__(self):
      return f"{self.first_field} ({self.second_field'})"

然后您的管理视图应将每个对象显示为“foo (bar)”

它显示您在 ModelA 中定义的 __str__(…) 方法的结果,因此如果您 return 在 __str__(…)some_field 的值方法,那么它将 return 只有 some_field.

的数据

因此您可以更改此方法和 return 这两个字段:

class ModelA(models.Model):
    some_field_A = models.CharField()
    some_other_field_A = models.CharField()

    def <b>__str__</b>(self):
        return f'{self.some_field_A} {self.some_other_field_A}'