学生成绩管理系统-Django-基本功能

前言:

帮忙写一个成绩管理系统,哇......
要求:

  1. 能按班级、按课程完成对学生成绩的增删改查;
  2. 能按班级、按课程统计学生的成绩,能求总分、平均分,课程的不及格人数等;
  3. 能按班级、按课程对学生的成绩进行排序;
  4. 能查询某名学生的成绩。
    嗯~ o( ̄▽ ̄)o,不管怎么看这都像是存粹的数据库操作。
    python 自带 sqlite3,而且后台傻瓜式操作数据库,最简单,就这个。
    技术选型:Python3.6+Django2.x+Xadmin2.x
    强力参考:

环境搭建

安装,当然是跳过啊!
最后面有详细依赖库,自己安装去。


初始化操作

D:\PRJ\student_management\Django_simple (master -> origin)
(py36) λ django-admin.exe startproject Django_simple # 
D:\PRJ\student_management\Django_simple (master -> origin)
(py36) λ python manage.py startapp app
D:\PRJ\student_management\Django_simple (master -> origin)
(py36) λ mkdir templates && mkdir static
D:\PRJ\student_management\Django_simple (master -> origin)
(py36) λ python manage.py migrate

初始目录树:

eor@DESKTOP-CNB2LNA:/mnt/d/PRJ/student_management/Django_simple$ tree -L 2 --filelimit 20
.
├── app
│   ├── admin.py
│   ├── apps.py
│   ├── __init__.py
│   ├── migrations
│   ├── models.py
│   ├── tests.py
│   └── views.py
├── db.sqlite3
├── Django_simple
│   ├── __init__.py
│   ├── __pycache__
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
├── manage.py
├── static
└── templates

往 setting.py 添加模块,注意添加自己的模块,否则无法导入数据库:

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'xadmin',
    'crispy_forms',
    'app',
]

测试 xadmin 是否抽风

作为后台管理系统,我们需要一个管理员,否则登陆不进去,新建管理员:


image.png

登陆成功


image.png

添加中文支持

往 setting.py 中导入

from django.utils.translation import ugettext_lazy as _

然后修改 LANGUAGE_CODE 和 LANGUAGES:


image.png

<center>结果</cemter>


image.png

参考:广告DN

使用数据库

修改 models.py:

from django.db import models

# verbose_name 作为说明注释使用,可用于 csv 导出
class Student(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)
    enter_date = models.DateField(verbose_name='入学时间')
    remarks = models.TextField(verbose_name='备注', blank=True)

需要明白的是,这里创建的是单个人物的数据模型,之后 Django 就能通过这个样板模型来进行数据的创建。

更新数据库:

D:\PRJ\student_management\Django_simple (master -> origin)
(py36) λ python manage.py makemigrations && python manage.py migrate

每次更改 models.py 都要运行一次 python manage.py makemigrations 和 python manage.py migrate。

啊,本质上 orm 就是将原本直接硬写的 sql 语句换成了 python 语句来写,这样我们就不需要记忆那些难记的 sql 语句了,但是也因为换成了 py 语句,所以我们需要手动对我们的 py 语句进行检测改动,然后被 orm 转换,最后作用于数据库。

SQLiteStudio 查看更改:


image.png

编写控制台信息

控制台由 admin.py 控制,最后用 xadmin.site.register 来注册上去。

# from django.contrib import admin
import xadmin
from app.models import *

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

xadmin.site.register(Student, StudentsAdmin)

上传图片、附件,仅限开发环境

添加相关目录到 setting.py:

# 以下仅限开发环境,这不适合生产使用!
# 媒体文件根目录
MEDIA_URL = '/media/' # 网站的访问路径
MEDIA_ROOT = os.path.join(BASE_DIR, 'media') # MEDIA_ROOT 为提供图片的路径

往 models.py 的内 student 类新加入一个图片属性并设置 upload_to,这将会被解释为数据库上传图片:

class Student(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)
    enter_date = models.DateField(verbose_name='入学时间')
    remarks = models.TextField(verbose_name='备注', blank=True)
    pass
    def path_photo(self, filename):
        return os.path.join('photo', '%s_%s' % (self.name, self.sex))
    photo = models.ImageField(verbose_name='照片', upload_to=path_photo, blank=True, null=True) # upload_to指定图片上传的途径,如果不存在则自动创建

编写 urls.py:

from django.contrib import admin
from django.urls import path
import xadmin
from django.conf import settings
from django.conf.urls.static import static

urlpatterns = [
    path(r'', xadmin.site.urls),
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

注意

此辅助函数仅在调试模式下有效,并且仅当给定前缀是本地(例如/media/)而不是URL(例如 http://media.example.com/)时才有效。

配置完 Django 的后台管理页面就会自动显示上传图片的功能,网站访问时的相对路径则由 MEDIA_URL 提供。

真素神奇,就跟配置文件一样,这里面 TM 发生了什么?

测试:


image.png

导出依赖库

不给完整依赖库的都是大坑,节省时间乃是大事。
导出依赖库:

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

安装依赖:

pip install -r requirements.txt

看一眼,可以复制下来存到自己的 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阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350