django 1.2 change_list 中显示ForeignKey中的列

本文介绍如何在 Django 的 Admin 后台界面中显示关联模型的特定字段,通过自定义方法并使用这些方法作为 list_display 属性来实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有如下Model

from django.db import models
from django.utils.encoding import force_unicode

# Create your models here.

class People(models.Model):
name = models.CharField(max_length = 200)
def __unicode__(self):
return force_unicode(self.name)

class Buy(models.Model):
from_people = models.ForeignKey(People, related_name = 'sale')
to_people = models.ForeignKey(People, related_name = 'buyer')
price = models.IntegerField()
def __unicode__(self):
return force_unicode(u'%s-%s-%s' % (self.from_people, self.to_people, self.price))


欲在Buy对象的admin的change_list页面中显示from_people和to_people的名称,应该怎么做呢?
[img]http://dl.iteye.com/upload/picture/pic/74156/ec2cbe61-50f9-3596-9b45-c21f82f844bf.jpg[/img]

找到的定制方法如下:
admin.py

import django.contrib.admin.sites as djsite
import django.contrib.admin.options as djopt
from django.utils.encoding import force_unicode
from django.db.models.fields.related import RelatedField
import models as mym

def normal_format(val):
return force_unicode(u'%s' % val)

def make_func(model, admin_order_field, format_fun = normal_format,
short_description = None, allow_tags = False,
use_self = False):
lst = admin_order_field.split('__')
def func_internal(self, obj = None):
if not use_self:
obj = self
s = ''
for s in lst:
obj = getattr(obj, s, None)
if not obj:
return force_unicode(admin_order_field)
return format_fun(obj)
if not short_description:
i = 0
while i < len(lst):
s = lst[i]
i += 1
model = model._meta.get_field_by_name(s)[0]
if isinstance(model, RelatedField):
model = model.rel.to
short_description = model.verbose_name
func_internal.short_description = short_description
func_internal.allow_tags = allow_tags
func_internal.admin_order_field = admin_order_field
return func_internal

class PeopleModelAdmin(djopt.ModelAdmin):
list_display = ['name']

class BuyModelAdmin(djopt.ModelAdmin):
saler_name = make_func(mym.Buy, 'from_people__name')
buyer_name = make_func(mym.Buy, 'to_people__name')
list_display = [saler_name, buyer_name, 'price']

djsite.site.register(mym.People, PeopleModelAdmin)
djsite.site.register(mym.Buy, BuyModelAdmin)


#admin.py end

按照上面的方法修改后,change_list页面中的显示为:
[img]http://dl.iteye.com/upload/picture/pic/74158/a889fcd8-1c58-35c5-a957-9c7483a60d9f.jpg[/img]
simpleui能给个完整代码吗?另外simpleui我的自定义按钮功能我希望是放在simpleui后台管理里的booklist管理页面上的添加类别的功能。这我的表from django.db import models Create your models here. 书籍类型表 class BookType(models.Model): book_type_id = models.AutoField(primary_key=True) book_type_name = models.CharField(max_length=255) def __str__(self): return self.book_type_name class Meta: db_table = 'BookType' #书籍表 class booklist(models.Model): id = models.AutoField(“id”, primary_key=True) bookId = models.CharField(“书籍编号”, max_length=255, default=“”) tag = models.ForeignKey( BookType, on_delete=models.CASCADE) title = models.CharField(“书名”, max_length=255, default=“”) cover = models.CharField(“封面”, max_length=2555, default=“”) author = models.CharField(“作者”, max_length=255, default=“”) press = models.CharField(“出版社”, max_length=255, default=“”) year = models.CharField(“出版年份”, max_length=255, default=“”) pageNum = models.CharField(“页码”, max_length=255, default=“”) price = models.CharField(“价格”, max_length=255, default=“”) rate = models.CharField(“评分”, max_length=255, default=“”) startList = models.CharField(“星级表”, max_length=255, default=“”) summary = models.TextField(“描述”,default=“”) detailLink = models.CharField(“详情链接”, max_length=255, default=“”) createTime = models.CharField(“创建时间”, max_length=2555, default=“”) class Meta: db_table = "booklist" #用户表 class User(models.Model): id = models.AutoField(“id”, primary_key=True) username = models.CharField(“用户名”,max_length=255, default=“”) password = models.CharField(“密码”,max_length=255, default=“”) age = models.CharField(“年龄”, max_length=255, default=“”) gender = models.CharField(“性别”, max_length=255, default=“”) createTime = models.DateTimeField(“创建时间”,auto_now_add=True) class Meta: db_table = "user" #将来要做评分表 class Rating(models.Model): id = models.AutoField(“评分ID”, primary_key=True) user_id = models.ForeignKey(User, on_delete=models.CASCADE, verbose_name=“用户ID”) book_id = models.ForeignKey(booklist, on_delete=models.CASCADE, verbose_name=“书籍ID”) rating = models.IntegerField(“评分”, default=0) # 假设评分为1-5的整数 rating_time = models.DateTimeField(“评分时间”, auto_now_add=True) def __str__(self): return f"{self.user_id.username} - {self.book_id.title} - {self.rating}" class Meta: db_table = "rating" 收藏表 class Collection(models.Model): id = models.AutoField(“收藏ID”, primary_key=True) user_id = models.ForeignKey(User, on_delete=models.CASCADE, verbose_name=“用户ID”) book_id = models.ForeignKey(booklist, on_delete=models.CASCADE, verbose_name=“书籍ID”) collection_time = models.DateTimeField(“收藏时间”, auto_now_add=True) def __str__(self): return f"{self.user_id.username} - {self.book_id.title} - 收藏" class Meta: db_table = "collection" 公告表 class Announcement(models.Model): announcement_id = models.AutoField(primary_key=True) content = models.TextField() timestamp = models.DateTimeField(auto_now_add=True) def __str__(self): return f"公告 {self.announcement_id}" class Meta: db_table = "announcement" 评论表 class Comment(models.Model): comment_id = models.AutoField(primary_key=True) user_id = models.ForeignKey(User, on_delete=models.CASCADE) book_id = models.ForeignKey(booklist, on_delete=models.CASCADE) parent_comment_id = models.ForeignKey(‘self’, null=True, blank=True, on_delete=models.CASCADE) content = models.TextField() timestamp = models.DateTimeField(auto_now_add=True) def __str__(self): return f"评论 {self.comment_id} - 用户 {self.user_id.username} - 书籍 {self.book_id.title}" class Meta: db_table = "comment"
03-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值