我有两个模型和一个管理模型:
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所以这就是为什么我把它放在一个单独的模型中。有什么建议吗?如果我必须改变模型以获得最佳结果,我不介意。
答案 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)
此代码不完整 - 您有两个来自Friends
到Person
的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