学生成绩管理系统-Django-扩展功能

前言:

基本功能已经走通,剩下的无非就是将其扩展直至符合需求罢了。
本篇大量参考自: 学生信息管理系统

要求:

  1. 能按班级、按课程完成对学生成绩的增删改查;
  2. 能按班级、按课程统计学生的成绩,能求总分、平均分,课程的不及格人数等;
  3. 能按班级、按课程对学生的成绩进行排序;
  4. 能查询某名学生的成绩。

班级模块

在添加一个类到 models.py 去:

class Class(models.Model):
    class_name = models.CharField(verbose_name='班级', max_length=100)

一个班级 N 个学生,那就是一对多啦,往 Student 类丢一个外键:

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

将数据注册进后台系统,往 admin.py 中添加:

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

<center>测试:</center>


image.png

image.png

在学生加入班级的界面有 bug,名字的显示不友好,应该是班级的名称而不是什么 Class object(1)。

瞧了瞧,这瓜皮的名字,这该不会就是类实例的打印吧?改一波实例的字符串显示:

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

<center>测试:</center>


image.png

居然成功了,真素神奇。


课程模块

一个学生 N 门课,一个课 N 个学生,那就是多对多啦,往 Student 类丢一个 ManyToManyField:

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

注意要重启开发服务器才能创建新的数据表。
<center>测试:</center>


image.png

创建教师模块

先加入模型:

class Teacher(models.Model):
    name = models.CharField(verbose_name='教师姓名', max_length=50)
    def __str__(self):
        return self.name

建立与班级联系,一个班只能有一个班主任,建一对一的联系,建立在 Class 类:

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

注意一对一关系的级联删除,当删除主表的数据时候从表中的数据也随着一起删除。
最后注册进后台:

class TeacherAdmin(object):
    list_display = ('name',)

xadmin.site.register(Teacher, TeacherAdmin)

<center>测试班主任功能:</center>


image.png

image.png

成绩模块

随便搞搞吧,就两步。
第一步,添加进 models:

class ExamReport(models.Model):
    student = models.ForeignKey(to=Student, on_delete=models.CASCADE, verbose_name='学生名称')
    subject = models.ForeignKey(to=Subject, on_delete=models.CASCADE, verbose_name='所选科目')
    exam_score = models.IntegerField(verbose_name='考试成绩')
    class Meta:
        db_table = ''
        managed = True
        verbose_name = '成绩'
        verbose_name_plural = '成绩集'
    def __str__(self):
        return "%s的%s的成绩" % (self.student.name, self.subject.name)

第二步,注册进后台:

class ExamReportAdmin():
    list_display = ('student', 'subject', 'exam_score')

xadmin.site.register(ExamReport, ExamReportAdmin)

image.png

增删改就算了,网页上傻瓜化操作了已经,但是查询功能由于涉及数据库的范围,需要我们自己设定。
往 admin.py 的 StudentAdmin 类加入搜索框,这里我们设定可以根据学生的名字、班级和选修课来搜索:

search_fields = ('name', 'class_name__class_name', 'subjects__name')

在使用 Django admin 系统中的搜索时可能会出现“related Field has invalid lookup: icontains”错误,主要原因是外键查询是需要指定相应的字段的。外键不应该只是一个model,而该是另一个表的明确的一个字段。所以我们需要指定特定的字段 "本表外键字段__外键所在表需查询字段"。

image.png

搜索 “一年三班”:


image.png

成了,其他的慢慢把搜索按需求加上就 OK 了。


下拉选择--人性化修饰

很多东西是一个被局限的集合,比如性别就只能有三种,科目只能有 n 种,老师的身份只能有 n 种,这时候可以提供个方便下拉来快速选择。
下拉的实现在 Dajngo 中很简单,就是往模型加一个 choices 的选项,这样在后台生成数据时就会自动生成下拉框啦。

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

注意 choices 的要求:'choices' must be an iterable containing (actual value, human readable name) tuples.

<center>测试:</center>


image.png

自定义管理界面--人性化修饰

Django 后台管理系统的信息由 Class Mate 定义,比如自定义 Students 的名字为中文:

    class Meta:
        db_table = ''
        managed = True
        verbose_name = '学生'
        verbose_name_plural = '学生集'

但是更新数据库时跳错:

django.db.utils.NotSupportedError: Renaming the 'app_class' table while in a transaction is not supported on SQLite because it would break referential integrity. Try adding `atomic = False` to the Migration class.

这倒是直白,就是 SQLite 数据库不支持重命名的操作,添加atomic = False即可,emmmm......
好,改!
Migration 在 \py36\Lib\site-packages\django\db\migrations\migration.py 的位置,看 49 行:

image.png

改成 False:

atomic = False

再怼:


image.png

成了。


定制网站信息--人性化修饰

修改登陆界面的标题,怼到 admin.py 里面去:

from xadmin.views.website import LoginView

class LoginViewAdmin(LoginView):
    title = '学生信息管理系统'

xadmin.site.register(LoginView, LoginViewAdmin)
image.png

修改后台管理页面左上角的信息和低下的版权信息:

from xadmin.views import CommAdminView

class GlobalSetting(CommAdminView):
    # 左上角及浏览器标题
    site_title = '学生信息管理系统'
    # 页脚版权信息
    site_footer = 'Copyright © 2018 eor'

xadmin.site.register(CommAdminView, GlobalSetting)

其实可以直接更改模板来着,毕竟这些也是根据模板生成的,不过这样修改集中到 admin.py 感觉还不错。


导出依赖文件

D:\PRJ\student_management\Django_simple (master -> origin)
(py36) λ pip freeze > requirements.txt

D:\PRJ\student_management\Django_simple (master -> origin)
(py36) λ cat requirements.txt
asn1crypto==0.24.0
astroid==2.0.1
autopep8==1.3.5
certifi==2018.8.13
cffi==1.11.5
colorama==0.3.9
cryptography==2.2.2
diff-match-patch==20121119
Django==2.1
django-crispy-forms==1.7.2
django-filter==2.0.0
django-formtools==2.1
django-import-export==1.0.1
django-reversion==3.0.0
djangorestframework==3.8.2
et-xmlfile==1.0.1
future==0.16.0
httplib2==0.9.2
idna==2.7
isort==4.3.4
jdcal==1.4
Jinja2==2.10
lazy-object-proxy==1.3.1
Markdown==2.6.11
MarkupSafe==1.0
mccabe==0.6.1
mysqlclient==1.3.13
odfpy==1.3.6
openpyxl==2.5.5
Pillow==5.2.0
pycodestyle==2.4.0
pycparser==2.18
pylint==2.0.1
PyMySQL==0.9.2
pytz==2018.5
PyYAML==3.13
six==1.11.0
tablib==0.12.1
typed-ast==1.1.0
unicodecsv==0.14.1
wincertstore==0.2
wrapt==1.10.11
xadmin==2.0.1
xlrd==1.1.0
xlwt==1.3.0
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,524评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,869评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,813评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,210评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,085评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,117评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,533评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,219评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,487评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,582评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,362评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,218评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,589评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,899评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,176评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,503评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,707评论 2 335

推荐阅读更多精彩内容

  • 切换到创建项目的目录 cd C:\Users\admin\Desktop\DjangoProject创建名为pr...
    在努力中阅读 3,246评论 2 3
  • 模块间联系越多,其耦合性越强,同时表明其独立性越差( 降低耦合性,可以提高其独立性)。软件设计中通常用耦合度和内聚...
    riverstation阅读 2,054评论 0 8
  • Web框架之Django: (1)简介: Django是一个由Python写成开源的重量级Web应用框架,采用MT...
    老肖阅读 3,042评论 0 18
  • 董卿是一个集美貌与才华于一体的女人,有着众人羡慕和敬仰的职业,享受着万人瞩目的光彩照人。别人看到她风光无...
    4点半的恩赐阅读 142评论 0 0
  • 海威斯去一家上市公司应聘打字员,人事主管也没问什么,就直接叫他上班,只是强调了一句:“要知道,这是一份才半年的临时...
    喵小姐huan阅读 431评论 0 1