Django - 在admin list_display函数中包含来自foreignkey的数据

时间:2010-10-25 10:13:34

标签: django django-models

我有两个模型和一个管理模型:

class Person(models.Model):

    firstname = models.CharField(maxlength=50)
    surname = models.CharField(maxlength=50)

class Friends(models.Model):

    person1 = models.ForeignKey("Person")
    person2 = models.ForeignKey("Person")
    friendship_made = models.DateField()

class PersonAdmin(admin.ModelAdmin):
    list_display = ["firstname", "surname"]

我想在list_display中显示此人的朋友。我知道如果我在Person模型中有外键字段,我可以使用双下划线来引用它,例如person2__surname。但是当thr外键在另一个表中时,不知道怎么做。

在我的系统中,一个人一次只能与一个人成为朋友,所以如果外键在人模型中会更好但我想存储关于友谊的额外信息,例如它的制作日期(firendship_made所以这就是为什么我把它放在一个单独的模型中。有什么建议吗?如果我必须改变模型以获得最佳结果,我不介意。

3 个答案:

答案 0 :(得分:7)

您需要在FriendAdmin课程中创建类似的内容:

class UserAdmin(admin.ModelAdmin):
    list_display = (..., 'get_reviews')

    def get_reviews(self, obj):
        return obj.book.review
    get_reviews.short_description = 'Review'

答案 1 :(得分:0)

此代码不完整 - 您有两个来自FriendsPerson的ForeignKeys,因此其中至少有一个需要related_name属性来防止冲突。代码根本不会按原样运行。

如果某人只能与另一个人成为朋友,则应使用OneToOneField而不是ForeignKey。然后,您只需引用my_person.friend1.person1.surname,其中my_person是您开始使用的人,friend1是我上面提到的related_name值。

答案 2 :(得分:0)

Thans for your answer uvasal(这非常有帮助),但此代码的语法无效

你需要: 返回'%s'%(obj.book.review,) 要么 返回'%s'%obj.book.review