Python3.6+Django2.0+Xadmin2.0学生信息管理系统

一、创建模型

模型是表示我们的数据库表或集合类,并且其中所述类的每个属性是表或集合的字段,在 app/models.py 中定义

 

1、首先,导入models模块

from django.db import models

接下来创建个学生信息类,其中包含学生姓名、性别、年龄、入学时间、家庭住址等信息:

复制代码

class Students(models.Model):name = models.CharField(verbose_name='学生姓名', max_length=50)sex = models.CharField(verbose_name='性别', max_length=50)age = models.IntegerField(verbose_name='年龄')address = models.CharField(verbose_name='家庭住址', max_length=250, blank=True)enter_date = models.DateField(verbose_name='入学时间')remarks = models.TextField(verbose_name='备注', blank=True)

复制代码

在终端内执行这两个数据库修改同步的命令

python3 manage.py makemigrations
python3 manage.py migrate

现在看看数据库,已经有了这张我们已经创建好的表及相关字段:

 

2、创建好数据表之后,接下来要将数据模型展示到页面

首先,将app/admin.py文件重命名为adminx.py,并导入模块

import xadmin
from .models import *

在前面我们已经创建好了一张包含学生姓名、性别、年龄、入学时间、家庭住址等信息的数据表,现在如果想要让其中的学生姓名、性别、年龄、入学时间显示在界面上,那就要创建一个类,其中的 list_display 属性包含需要展示在页面的相关字段:

class StudentsAdmin(object):list_display = ('name', 'sex', 'age', 'address',)

最后,对其进行注册:

xadmin.site.register(Students, StudentsAdmin)

来看看页面长得是这样子的:

 

3、本地化语言显示

是否发现左侧栏目显示的还是Students,咦,不对,怎么会是Students呢?原因就在于,英文单词有单数和复数之分,左侧这一栏默认是以类名最后加's'作为复数显示的。那我们想要把它改为中文,要怎么做呢?接下来,就来操作:

在models.py的Students类下添加类属性:

复制代码

class Students(models.Model):name = models.CharField(verbose_name='学生姓名', max_length=50)sex = models.CharField(verbose_name='性别', max_length=50)age = models.IntegerField(verbose_name='年龄')address = models.CharField(verbose_name='家庭住址', max_length=250, blank=True)enter_date = models.DateField(verbose_name='入学时间')remarks = models.TextField(verbose_name='备注', blank=True)class Meta:verbose_name = '学生信息'verbose_name_plural = '学生信息'def __str__(self):return self.name

复制代码

 

 4、下拉选项

到这里,我们会发现在添加学生信息的时候,其中有一个性别字段,每次都要手动输入“男”/“女”,要是弄成下拉选择框,那就省事了,有办法:

在Students类里添加

    SEX = (('male', '男'),('female', '女'))

然后修改sex字段

修改前:

sex = models.CharField(verbose_name='性别', max_length=50)

修改后:

sex = models.CharField(choices=SEX, verbose_name='性别', max_length=50)

同时,记得对模型的修改操作,凡是有涉及到数据库的,都要进行同步操作,运行命令:

python3 manage.py makemigrations
python3 manage.py migrate

 

*有了学生信息之后,还需要添加个学生所属的班级信息。同样的,在models.py里添加一个班级类:

复制代码

class Class(models.Model):class_name = models.CharField(verbose_name='班级', max_length=100)class Meta:verbose_name = '班级'verbose_name_plural = '班级'def __str__(self):return self.class_name

复制代码

*注意,这两个类必须写在Students类的上面,否则无法被Students类识别

还是一样,修改adminx.py,对这两个类进行注册和页面自定义展示操作:

class ClassAdmin(object):list_display = ('class_name',)xadmin.site.register(Class, ClassAdmin)

 

这里我们先把班级信息给填写完整,之后需要对Students类关联这这两张表

 

*外键的操作:

在Students类里添加:

    grade_name = models.ForeignKey(Grade, verbose_name='所在年级', on_delete=models.CASCADE, blank=True, null=True)class_name = models.ForeignKey(Class, verbose_name='所在班级', on_delete=models.CASCADE, blank=True, null=True)

这里的ForeignKey代表使用外键,用到的是我们上面创建好的年级和班级这两张表的信息,blank=True和null=True代表可以为空,非必填字段。

使用数据库同步命令:

python3 manage.py makemigrations
python3 manage.py migrate

 

学生需要有他要学习的课程,现在我们就来创建课程的数据表,同样的需要写在学生表前面:

models.py文件内添加:

复制代码

class Subjects(models.Model):name = models.CharField(verbose_name='课程名称', max_length=50, blank=True)score = models.IntegerField(verbose_name='学分', blank=True)class Meta:verbose_name = '课程信息'verbose_name_plural = '课程信息'def __str__(self):return self.name

复制代码

adminx.py文件内添加:

class SubjectsAdmin(object):list_display = ('name', 'score',)xadmin.site.register(Subjects, SubjectsAdmin)

 

*多对多关系:

一个学生需要选修的课程一般不少于1门,那就需要用到多对多关系:

修改Student类,添加一个选修课程字段:

subjects = models.ManyToManyField(Subjects, verbose_name='选修课程')

同步一下数据库信息,方法前面提到,这里不再赘述。

 

我们看到的选修课程的选项似乎有点丑,而且一旦选择了就无法取消。这就需要对adminx.py进行修改,自定义显示风格:

在StudentsAdmin内中添加一个内联复选框:

style_fields = {'subjects': 'checkbox-inline', }

这里要注意一个地方,刚才我们在Students类中创建subjects字段时,没有设置其为非必填字段,这里就会导致必须勾选了所有选项之后才让保存。所以,正确的做法应该是要修改Students中的subjects字段,加入blank=True

subjects = models.ManyToManyField(Subjects, verbose_name='选修课程', blank=True)

(xadmin2.0貌似有个bug,这里本来应该显示横排的复选框,但是却显示成了竖着的,在Django1.x+xadmin0.6的组合里使用显示是正常的)

 

有了学生之后,我们再来创建教师信息表:

models.py文件中加入:

复制代码

class Teachers(models.Model):name = models.CharField(verbose_name='教师姓名', max_length=50)class Meta:verbose_name = '教师信息'verbose_name_plural = '教师信息'def __str__(self):return self.name

复制代码

adminx.py文件中加入:

class TeachersAdmin(object):list_display = ('name',)xadmin.site.register(Teachers, TeachersAdmin)

不要忘记了同步数据库。

 

*一对一关系:

  假设学校规定,一个教师只能担任一个班级的班主任,那就需要用到一对一关系:

修改models.py的Class表,添加headmaster字段:

headmaster = models.OneToOneField(Teachers, verbose_name='班主任', on_delete=models.CASCADE, blank=True, null=True)

这里的OneToOneField就是一对一关系了,执行数据库同步命令。

现在在页面上的班级信息里选择班主任,一个班主任在被一个班级选定之后,其他班级是无法再选择的:

 

具体源码内容  请关注学长公众号回复“Django”

 

公众号二维码                 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/456814.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

升级 pip版本

安装第三方库:pip install Pillow 出现 You are using pip version 7.1.2, however version 9.0.1 is available. You should consider upgrading via the python -m pip install --upgrade pip comm and. 解决方法1: 输入“python -m pip install -U pi…

大数据集群搭建之节点的网络配置过程(二)

紧接着上一章来设置windows的vmnet8的ip地址和虚拟机中centos的ip地址。 NAT虚拟网络的配置图如下图所示: 1、这里根据VMware中得到的网关地址去设置vmnet8的ip地址。 网关地址查看: 2、得到的网关地址后去设置vmnet8,将网关地址设置为v…

Python3.6+Django2.0+Xadmin2.0学生信息管理系统-2

1、上传图片/文件等资源 有时候需要添加一些附件,例如,新生刚入学,大家相互之间还不熟悉,希望能通过照片来加深印象,并且方便教学管理。 首先,对demo/urls.py文件进行改造,给urlpatterns添加s…

pycharm之no python interpreter configured for project的解决办法

今天由于重装了系统,所以必须得重新配置一些软件,在打开pycharm运行程序时显示“no python interpreter configured for project”提示。根据字面意思是“python没有解释器”。 解决办法: 找到你之前下载python环境支持库如下图所示&#x…

Python是非常优美的语言,那到底如何个美呢?

我把Python里面非常有名的简洁,高效,方便的代码整理出来,让我们来一睹她的风采。其实每个主题展开讲都是很大的篇幅,今天我们先overview一下 看完之后,相信初学者会更快的喜欢上python. 1.列表推导 要说Python里面最…

大数据集群搭建之hadoop、tomcat、jdk等工具的安装(三)

目录一、准备的资源:二、安装配置过程 目录 本章就说下各种软件的安装和配置。 一、准备的资源: 1、tomcat(如用于在网页上查看HDFS的存储等) 地址:http://pan.baidu.com/s/1miC93ny 密码:52dd 2、jdk 地址:ht…

pycharm 快捷键大全

1、编辑(Editing) Ctrl Space 基本的代码完成(类、方法、属性) Ctrl Alt Space 快速导入任意类 Ctrl Shift Enter 语句完成 Ctrl P 参数信息(在方法中调用参数) Ctrl Q 快速查看文档 F1 Web帮…

转载 Spark性能优化指南——基础篇

前言 在大数据计算领域,Spark已经成为了越来越流行、越来越受欢迎的计算平台之一。Spark的功能涵盖了大数据领域的离线批处理、SQL类处理、流式/实时计算、机器学习、图计算等各种不同类型的计算操作,应用范围与前景非常广泛。在美团•大众点评&#xff…

Pycharm新建文件时自动添加基础信息

# -*- coding: utf-8 -*- # Time : ${DATE} ${TIME} # Author : Liu # File : ${NAME}.py 如下图所示 再建一个py文件时就会自动添加信息: # -*- coding: utf-8 -*- # Time : 2019/05/05 11:46 # Author : Liu # File : DOUBAN.py

Linux中的crontab详解

linux系统则是由 cron (crond) 这个系统服务来控制的。Linux 系统上面原本就有非常多的计划性工作,因此这个系统服务是默认启动的。另外, 由于使用者自己也可以设置计划任务,所以, Linux 系统也提供了使用者控制计划任务的命令 :crontab 命令…

实现一个简单的前端水印

需求分析 水印效果如下: 除了直观需求,还有非直观需求。 这是个背景图。文字样式以及文字本身可调整。对于需求1,需要前端生成图片的能力。 该能力的原理:借用canvas.toDataURL()或者(new XMLSerializer()).serializeToString()生…

QQ客服聊天功能网页跳转只需要几行代码

<html><head><meta charset"utf-8"></head><body><a target"_blank" href"http://wpa.qq.com/msgrd?v3&uin客服QQ号&siteqq&menuyes"><img border"0" src"http://wpa.qq.co…

Linux环境下Mysql的安装教程及安装过程常见问题的解决方法

最近安装mysql时看到一篇不错的文章 1、下载 下载地址&#xff1a;http://dev.mysql.com/downloads/mysql/5.6.html#downloads 下载版本&#xff1a;我这里选择的5.6.33&#xff0c;通用版&#xff0c;linux下64位 也可以直接复制64位的下载地址&#xff0c;通过命令下载&a…

Spark分布式集群的搭建和运行

集群共三台CentOS虚拟机&#xff0c;一个Matser&#xff0c;主机名为master&#xff1b;三个Worker&#xff0c;主机名分别为master、slave03、slave04。前提是Hadoop和Zookeeper已经安装并且开始运行。 1. 在master上下载Scala-2.11.0.tgz&#xff0c;复制到/opt/下面&#xf…

Hive2.1.1的安装教程(元数据放在本地Mysql)

目录1.上传tar包2.解压3. 设置环境变量4.设置Hive的配置文件5.启动Hive6.安装MySQL7.下载MySQL的驱动包8.修改Hive的配置文件9.启动Hive10.查看MySQL数据库 目录 1.上传tar包 jar包地址&#xff1a;http://hive.apache.org/downloads.html 2.解压 tar -zxvf apache-hive-2…

App性能优化之内存优化

2019独角兽企业重金招聘Python工程师标准>>> 为什么要进行内存优化呢&#xff1f;其实我们可以反过来想。如果不进行内存优化会产生什么样的问题&#xff1f; App的运行是有内存限制的&#xff0c;超过限制会产生OOM&#xff0c;导致App崩溃。如果内存不进行优化&am…

Linux 网络编程详解四(流协议与粘包)

TCP/IP协议是一种流协议&#xff0c;流协议是字节流&#xff0c;只有开始和结束&#xff0c;包与包之间没有边界&#xff0c;所以容易产生粘包&#xff0c;但是不会丢包。 UDP/IP协议是数据报&#xff0c;有边界&#xff0c;不存在粘包&#xff0c;但是可能丢包。 产生粘包问题…

执行Hive语句报错:FAILED: Error in metadata: javax.jdo.JDOFatalDataStoreException: Access denied for user '

安装个Hive真不省心&#xff0c;各种问题。最近安装好Hive后执行Hive语句时碰到这样的错误&#xff1a; hive> show databases; FAILED: Error in metadata: javax.jdo.JDOFatalDataStoreException: Access denied for user rootlocalhost (using password: YES) NestedThr…

阿里云部署django项目流程【centos7+python3+mysql】

购买阿里云服务器 到[阿里云官网]&#xff0c;选择轻量应用服务器&#xff0c; 步骤如图所示&#xff1a; 地域随便选择哪一个&#xff0c;镜像的话&#xff0c;对比了CentOS&#xff0c;Debian&#xff0c;Ubuntu&#xff0c;我最终选择了CentOS&#xff0c;因为流行嘛&…

对于频繁的写数据处理方式

添加一个新的表情的时候 调用 recentEmotions方法 将所有表情写入数组 每次都是 添加一个新的表情进来 要将沙盒中的所有表情首先加载进数组&#xff0c;然后将表情添加到数组里面 然后在将数组写入沙盒 处理方式 没有必要每次都要到沙盒里面读取数组文件 类方法 不能访问 成员…