Django2.0+xadmin入门教程之学生信息管理系统(上)

一、创建子应用

在Web应用中,通常有一些业务功能模块是在不同的项目中都可以复用的,故在开发中通常将工程项目拆分为不同的子功能模块,各功能模块间可以保持相对的独立,在其他工程项目中需要用到某个特定功能模块时,可以将该模块代码整体复制过去,达到复用。

我们先创建一个Student的子应用出来,可参考:

https://blog.csdn.net/yuezhuo_752/article/details/84101218

 

二、创建模型

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

1、首先,导入models模块

from django.db import models

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

 
  1. from django.db import models

  2.  
  3. # Create your models here.

  4. class Students(models.Model):

  5. name = models.CharField(verbose_name='学生姓名', max_length=50)

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

  7. age = models.IntegerField(verbose_name='年龄')

  8. address = models.CharField(verbose_name='家庭住址', max_length=250, blank=True)

  9. enter_date = models.DateField(verbose_name='入学时间')

  10. remarks = models.TextField(verbose_name='备注', blank=True)

在终端内执行这两个数据库修改同步的命令,记住,要先在settings.py吧自己的子应用添加上去

 
  1. python manage.py makemigrations

  2. python manage.py migrate

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

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

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

 
  1. import xadmin

  2. from .models import *

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

 
  1. class StudentsAdmin(object):

  2. list_display = ('name', 'sex', 'age', 'address',)

最后,对其进行注册:

xadmin.site.register(Students, StudentsAdmin)

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

3、本地化语言显示

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

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

 
  1. from django.db import models

  2.  
  3. # Create your models here.

  4. class Students(models.Model):

  5. name = models.CharField(verbose_name='学生姓名', max_length=50)

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

  7. age = models.IntegerField(verbose_name='年龄')

  8. address = models.CharField(verbose_name='家庭住址', max_length=250, blank=True)

  9. enter_date = models.DateField(verbose_name='入学时间')

  10. remarks = models.TextField(verbose_name='备注', blank=True)

  11.  
  12. class Meta:

  13. verbose_name = '学生信息' #这个是修改增加xx 按钮名字

  14. verbose_name_plural = '学生信息' #这个是修改显示Studentss文字

  15.  
  16.  
  17. def __str__(self):

  18. return self.name

 

4、下拉选项

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

在Students类里添加

 
  1. SEX = (

  2. ('male', '男'),

  3. ('female', '女')

  4. )

然后修改sex字段

修改前:

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

修改后:

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

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

 
  1. python manage.py makemigrations

  2. python manage.py migrate

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

 
  1. class Class(models.Model):

  2. class_name = models.CharField(verbose_name='班级', max_length=100);

  3.  
  4. class Meta:

  5. verbose_name = '班级'

  6. verbose_name_plural = '班级'

  7.  
  8. def __str__(self):

  9. return self.class_name

*注意,这个类必须写在Students类的上面,否则后面添加外键时无法被Students类识别

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

 
  1. class StudentsAdmin(object):

  2. list_display = ('name', 'sex','age', 'address')

  3.  
  4. class ClassAdmin(object):

  5. list_display = ('class_name',)# 加上逗号,类型为元组 不然会报AttributeError错

  6.  
  7.  
  8. xadmin.site.register(Students,StudentsAdmin)

  9. xadmin.site.register(Class, ClassAdmin)

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

 

*外键的操作:

在Students类里添加:

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

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

同样,别忘了使用数据库同步命令:

 
  1. python manage.py makemigrations

  2. python manage.py migrate

 

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

models.py文件内添加:

 
  1. class Subjects(models.Model):

  2. name = models.CharField(verbose_name='课程名称', max_length=50, blank=True)

  3. score = models.IntegerField(verbose_name='学分', blank=True)

  4.  
  5. class Meta:

  6. verbose_name = '课程信息'

  7. verbose_name_plural = '课程信息'

  8.  
  9. def __str__(self):

  10. return self.name

adminx.py文件内添加:

 
  1. class SunbectsAdmin(object):

  2. list_display = ('name','score')

  3.  
  4.  
  5. xadmin.site.register(Subjects, SunbectsAdmin)

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

然后手动添加一些课程进去

*多对多关系:

一个学生需要选修的课程一般不少于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文件中加入:

 
  1. class Teachers(models.Model):

  2. name = models.CharField(verbose_name='教师姓名', max_length=50)

  3.  
  4. class Meta:

  5. verbose_name = '教师信息'

  6. verbose_name_plural = '教师信息'

  7.  
  8. def __str__(self):

  9. return self.name

adminx.py文件中加入:

 
  1. class TeachersAdmin(object):

  2. list_display = ('name',)

  3.  
  4.  
  5. xadmin.site.register(Teachers, TeachersAdmin)

  6.  

不要忘记了同步数据库。

 

*一对一关系:

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

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

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

注:Teachers这个类要在Class类上面,理由前面有提到。

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

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

 

转载原文:https://www.cnblogs.com/v88v/p/8886764.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值