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

摘要:
前言如果xadmin后台想要添加、删除、修改和查询表内容,就像以前admin中编写的注册表信息一样。py文件,您需要创建一个新的adminx。py文件位于admin.py的同一级别目录中。然后单击admin。py文件控制要在页面上显示的内容。模型模块模型模块与先前的设计表相同。它显示在模型中设计表的字段中。py文件。以学生表为例。
前言

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 

 遇到报错1python测试开发django(33)--xadmin注册表信息第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,登录后,后台页面显示;

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

学生成绩新增页面;

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

 银行卡账户使用inlines关联过来的页面显示

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

免责声明:文章转载自《python测试开发django(33)--xadmin注册表信息》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Android之ViewPager 第二课JQuery window.opener下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

呵呵!手把手带你在 IIS 上执行 Python

公司的站点让我头痛死了。在众多前辈高手的带领下。一大堆的 CMD 在站点里执行得好好地,黑客攻击也好好地。仅仅有站点和我不好好地,我快累死了,站点快挂了。。 。 为了解决问题。我想到了 Python 来解决。但是站点上怎样执行 Python。 我在网上找了非常多资料。结果,互相抄来抄去的。问题层出不穷——各种问题都在我眼前显现。在我不断地瞎折腾,经理在...

六、Django的orm之单表操作

Django模型层(一)单表操作 一、ORM ORM是“对象-关系-映射”的简称。(Object Relational Mapping,简称ORM) orm其实就是将类对象的语法翻译成sql语句的一个引擎 类对象 --- sql 类 -- 表 对象 -- 行 属性 -- 字段 原生sql和Python的orm代码对比: 二、Django连接数据库 在Dj...

DATAX 实现python调用cmd 系统控制台,实现在开发工具中内嵌datax (python 多行执行cmd命令)

上代码 1 import os 2 if __name__=='__main__': 3 str="CHCP 65001"+"&&" 4 str+="E:"+"&&" 5 str += "cd E:\DATAX\datax\bin" + "&&" 6 str += "pytho...

数据看板superset在Windows环境下安装

@https://www.cnblogs.com/calmzeal/archive/2017/08/14/7359144.html 以下是我的安装版本与安装步骤: 1. 安装Python 3.7 ,python-3.7.1-amd64.exe 检查:CMD下 分别运行python -V 和 pip-V。如果找不到命令,则需要添加python的安装目录到pa...

linux中常见的脚本工具

1、Perl Perl脚本最初为在Unix系统中更好的处理文本报表而设计,经过多年的发展已经成为一种广泛应用的高级脚本语言。Perl脚本对文本文件的处理功能依然非常强大,在图像处理、系统管理、网络编程、数据库编程等方面可有其用武之地。 2、Python Python是最近几年发展非常快的一种脚本编程语言,它的设计理念非常重视代码的可读性,其最显著的语法特点...

Python 函数参数使用

默认参数 def ask_ok(prompt, retries=4, complaint='Yes or no, please!'): while True: ok = raw_input(prompt) if ok in ('y', 'ye', 'yes'): return True...