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
在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关联过来的页面显示