• python测试开发django(33)--xadmin注册表信息


    前言

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

  • 相关阅读:
    验证码的编写 asp.net
    甲骨文收购Sun,IT业界进入三国时代
    动态加载css文件导致IE8崩溃的问题
    页面调试中关于Console应该注意的地方
    关于仿网易邮箱5.0的Neter UI框架的开源声明
    仿网易邮箱5.0(二):core.js
    仿网易邮箱5.0(三):panel.js
    仿网易邮箱5.0(一):页面基本样式
    Windows下配置Sass编译环境
    ASP+Access查询时按时间进行查询
  • 原文地址:https://www.cnblogs.com/canglongdao/p/14121042.html
Copyright © 2020-2023  润新知