如何解决如何在 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
值不同:
解决方法
我不确定这是否正是您正在寻找的解决方案,但您可以覆盖 __str__
的 ModelA
方法以在一行中返回信息。
例如:
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)”
,它显示您在__str__(…)
中定义的ModelA
方法的结果,因此如果您在some_field
方法中返回__str__(…)
的值,那么它将返回仅some_field
的数据。
因此,您可以更改此方法并返回两个字段:
class ModelA(models.Model):
some_field_A = models.CharField()
some_other_field_A = models.CharField()
def __str__(self):
return f'{self.some_field_A} {self.some_other_field_A}'
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。