前言
xadmin后台如果要对表的内容增删改查,跟之前的admin.py文件里面写注册表信息一样,需在admin.py同一级目录新建一个adminx.py的文件。
然后在admin.py文件控制页面上需显示的内容。
models模块
models模块跟之前设计表是一样的,在models.py文件设计表的字段显示,以Studentts表为例。
# coding:utf-8
from django.db import models
# Create your models here.
class Studentts(models.Model):
'''学生成绩'''
student_ids = models.CharField(max_length=30, verbose_name="学号")
names = models.CharField(max_length=30, verbose_name="姓名")
age = models.IntegerField(verbose_name="年龄")
score = models.IntegerField(verbose_name="分数")
class Meta:
verbose_name = "学生成绩"
verbose_name_plural = verbose_name
如果有表的关联,以之前的admin后台一对一关系OneToOneField为例
class Cardds(models.Model):
'''银行卡 基本信息'''
card_id = models.CharField(max_length=30, verbose_name="卡号", default="")
card_user = models.CharField(max_length=10, verbose_name="姓名", default="")
add_time = models.DateField(auto_now=True, verbose_name="添加时间")
class Meta:
verbose_name = "银行卡账户_基本信息"
verbose_name_plural = '银行卡账户'
def __str__(self):
return self.card_id
class CardDetaills(models.Model):
'''银行卡详情信息'''
card = models.OneToOneField(Cardds,
on_delete=models.CASCADE,
verbose_name="卡号"
)
tel = models.CharField(max_length=30, verbose_name="电话", default="")
mail = models.CharField(max_length=30, verbose_name="邮箱", default="")
city = models.CharField(max_length=10, verbose_name="城市", default="")
address = models.CharField(max_length=30, verbose_name="详细地址", default="")
class Meta:
verbose_name = "账户_个人资料"
verbose_name_plural = verbose_name
def __str__(self):
return self.card.card_user
adminx.py文件
在admin.py文件的同一目录新建一个adminx.py(注意只能是adminx.py,不能叫其它的名称)
在adminx.py里与之前的admin.py代码有一些不一样
之前import admin,这里import xadmin
之前注册表时继承admin.ModelAdmin,这里继承object
之前inlines关联的表(class MoreInfo)继承admin.StackedInline,这里继承object
之前可以有2种注册方式,可以用装饰器方法@admin.register(表类名),这里只能通过xadmin.site.register(表类名,xxx)方式
#adminx.py
import xadmin
from .models import Studentts,Cardds,CardDetaills
class ControlStudent(object):
# 显示的字段
list_display = ('student_ids', 'names', 'age', 'score')
# 搜索条件
search_fields = ('name',)
# 每页显示10条
list_per_page = 10
class MoreInfo(object):
model = CardDetaills
class ControlCard(object):
list_display = ["card_id", "card_user", "add_time"]
# 在Card页面显示更多信息CardDetail
inlines = [MoreInfo]
# 注册Student表
xadmin.site.register(Studentts, ControlStudent)
# 注册card表,关联CardDetail
xadmin.site.register(Cardds, ControlCard)
执行:
python manage.py makemigrations
python manage.py migrate
python manage.py runserver
遇到报错1:
打开debug.py,找到 with Path(CURRENT_DIR, 'templates', 'technical_500.html').open() as fh: 将其改为:
with Path(CURRENT_DIR, 'templates', 'technical_500.html').open(encoding="utf-8") as fh:
问题2:不同工程下,使用同一数据库,app应用名相同,数据库相同,python manage.py migrate创建表时,提示“No migrations to apply”;
解决办法:https://blog.csdn.net/weixin_45921256/article/details/104555872
问题3:报错:django.db.utils.ProgrammingError:(1146,"Table" '表名' doesn't exist)
在数据库中删除一张表,重新执行python manage.py migrate时出错,提示不存在这张表;
解决办法:https://blog.csdn.net/weisubao/article/details/77187876
xadmin列表页面展示
打开http://127.0.0.1:8000/xadmin,登录后,后台页面显示;
学生成绩新增页面;
银行卡账户使用inlines关联过来的页面显示