Django 小实例S1 简易学生选课管理系统 9 创建课程模型(model)
Django 小实例S1 简易学生选课管理系统 第9节——创建课程模型(model)
点击查看教程总目录
作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师。
对于课程模块,需要:
- 课程表
- 学生课程表:学生和课程的关系表
- 时刻表:课程上课时间设置
由于课程会有多个状态,这个可以先在constants.py
中去记录好(即添加代码如下)
COURSE_STATUS = {
1: "未开始选课",
2: "开始选课",
3: "结束选课",
4: "结课",
5: "打分完成",
}
COURSE_OPERATION = {
1: "开始选课",
2: "结束选课",
3: "结课",
4: "给分",
5: "查看详情"
}
然后在course/models.py
中导入下面会需要的所有库
from django.db import models
import datetime
from user.models import Student, Teacher
from constants import COURSE_STATUS, COURSE_OPERATION
1 添加课程模型
在course/models.py
中添加代码如下
def current_year():
# refer: https://stackoverflow.com/questions/49051017/year-field-in-django/49051348
return datetime.date.today().year
class Course(models.Model):
credits = [
(1, 1),
(2, 2),
(3, 3),
(4, 4),
(5, 5),
]
semesters = [
("Autumn", "上"),
("Spring", "下")
]
name = models.CharField(max_length=50, verbose_name="课程名")
introduction = models.CharField(max_length=250, verbose_name="介绍")
credit = models.IntegerField(verbose_name="学分")
max_number = models.IntegerField(verbose_name="课程最大人数")
year = models.IntegerField(verbose_name="年份", default=current_year)
semester = models.CharField(max_length=20, verbose_name="学期", choices=semesters)
# 未开始选课, 1
# 开始选课,未结束选课 2
# 结束选课, 3
# 结课 4
# 已打完分 5
status = models.IntegerField(verbose_name="课程状态", default=1)
teacher = models.ForeignKey(Teacher, verbose_name="课程教师", on_delete=models.CASCADE)
def get_status_text(self):
return COURSE_STATUS[self.status]
def get_op_text(self):
return COURSE_OPERATION[self.status]
def get_current_count(self):
courses = StudentCourse.objects.filter(course=self, with_draw=False)
return len(courses)
def get_schedules(self):
schedules = Schedule.objects.filter(course=self)
return schedules
def __str__(self):
return "%s (%s)" % (self.name, self.teacher.name)
补充说明: get_status_text
和get_op_text
方法是为了方便在模板中调用。
2 添加课程时刻表模型
在course/models.py
中添加代码如下
def weekday_choices():
weekday_str = ['周一', '周二', '周三', '周四', '周五', '周六', '周日']
return [(i+1, weekday_str[i]) for i in range(7)]
class Schedule(models.Model):
weekday = models.IntegerField(choices=weekday_choices(), verbose_name="日期")
start_time = models.TimeField(verbose_name="上课时间")
end_time = models.TimeField(verbose_name="下课时间")
location = models.CharField(max_length=100, verbose_name="上课地点")
remarks = models.CharField(max_length=100, verbose_name="备注", null=True, blank = True)
start_week = models.IntegerField(verbose_name="第几周开始")
end_week = models.IntegerField(verbose_name="第几周结束")
intervals = [
(1, "无间隔"),
(2, "每隔一周上一次")
]
week_interval = models.IntegerField(verbose_name="周间隔", choices=intervals, default=1)
course = models.ForeignKey(Course, verbose_name="课程名", on_delete=models.CASCADE)
def __str__(self):
s = "第%s周-第%s周 " % (self.start_week, self.end_week)
if self.week_interval == 2:
s += "隔一周 "
s += "%s %s-%s " % (self.get_weekday_display(), self.start_time.strftime("%H:%M"),
self.end_time.strftime("%H:%M"))
s += "在%s" % self.location
if self.remarks:
s += " %s" % self.remarks
return s
3 添加学生课程关系表模型
在course/models.py
中添加代码如下
class StudentCourse(models.Model):
create_time = models.DateTimeField(auto_now=True)
with_draw = models.BooleanField(default=False)
with_draw_time = models.DateTimeField(default=None, null=True)
scores = models.IntegerField(verbose_name="成绩", null=True)
comments = models.CharField(max_length=250, verbose_name="老师评价", null=True)
rates = [
(1, 1),
(2, 2),
(3, 3),
(4, 4),
(5, 5),
]
rating = models.IntegerField(verbose_name="学生评分", choices=rates, null=True, help_text="5分为最满意,最低分是1分")
assessment = models.CharField(max_length=250, verbose_name="学生评价", null=True)
student = models.ForeignKey(Student, on_delete=models.CASCADE)
course = models.ForeignKey(Course, on_delete=models.CASCADE)
4 建立(更新)数据库
简单复述一遍,即在项目文件夹下打开命令行窗口,执行:
python manage.py makemigrations
python manage.py migrate
Django 小实例S1 简易学生选课管理系统 9 创建课程模型(model)的更多相关文章
- Django 小实例S1 简易学生选课管理系统 3 创建用户模型(model)
Django 小实例S1 简易学生选课管理系统 第3节--创建用户模型(model) 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 本文涉及到的新 ...
- Django 小实例S1 简易学生选课管理系统 10 老师课程业务实现
Django 小实例S1 简易学生选课管理系统 第10节--老师课程业务实现 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 课程模块中,老师将要使 ...
- Django 小实例S1 简易学生选课管理系统 12 CSS样式完善
Django 小实例S1 简易学生选课管理系统 第12节--CSS样式完善 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 课程模块的逻辑代码到这里 ...
- Django 小实例S1 简易学生选课管理系统 11 学生课程业务实现
Django 小实例S1 简易学生选课管理系统 第11节--学生课程业务实现 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 课程模块中,学生需要拥 ...
- Django 小实例S1 简易学生选课管理系统 8 CSS样式优化
Django 小实例S1 简易学生选课管理系统 第8节--CSS样式优化 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 前面的几节下来,用户模块基 ...
- Django 小实例S1 简易学生选课管理系统 7 修改个人信息
Django 小实例S1 简易学生选课管理系统 第7节--修改个人信息 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 用户模块除了注册登录之外,还 ...
- Django 小实例S1 简易学生选课管理系统 6 实现登录逻辑
Django 小实例S1 简易学生选课管理系统 第6节--实现登录逻辑 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 1 业务逻辑 本教程第四节里 ...
- Django 小实例S1 简易学生选课管理系统 2 新建项目(project)并进行设置
Django 小实例S1 简易学生选课管理系统 第2节--新建项目(project)并进行设置 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 0 ...
- Django 小实例S1 简易学生选课管理系统 4 实现登录页面
Django 小实例S1 简易学生选课管理系统 第4节--实现登录页面 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 本文涉及到的新的额外知识点: ...
随机推荐
- element-ui上传多个文件时会发送多个请求
1. element-ui的默认 默认是异步多次请求上传单个文件 如果业务就是单纯的上传文件,那么这个样子是没有问题的 前端代码参考 https://element-plus.gitee.io/#/z ...
- 一款简单实用的串口通讯框架(SerialIo)
前言 大龄程序员失业状态,前几天面试了一家与医疗设备为主的公司并录取:因该单位涉及串口通讯方面技术,自己曾做过通讯相关的一些项目,涉及Socket的较多,也使用SuperSocket做过一些项目,入职 ...
- [洛谷日报#204] StackEdit——Markdown 编辑器的功能介绍
本文同时发表于洛谷日报,您也可以通过洛谷博客进行查看. 1.介绍与开始使用 1.1 这是什么? StackEdit是基于PageDown.Stack Overflow和其他堆栈交换站点使用的Markd ...
- B站1024程序员节部分答案
1.页面的背后是什么? 直接撸页面源码就行啦 2.真正的秘密只有特殊的设备才能看到 修改UA为页面上提示的"bilibili Security Browser" 3.密码是啥? 弱 ...
- C++学习 1 数组
一维数组: 定义:1.数据类型 数组名 [ 数组长度 ]: int arr [5];//赋值 arr[0]=10; arr[1]=20; arr[2]=30; arr[3]=40; arr[4]=50 ...
- 开发数学系统时,需要掌握的几个基于Web的数学框架
在做数学系统时,经常要和数学公式打交道,这里介绍几个常用的基于Web的数学处理软件. 数学系统主要包括三类:(1)数学公式的显示,也就是如何使用web显示复杂的数学公式. (2)图像制作,例如长方形, ...
- Vue3学习(六)之使用Vue3进行数据绑定及显示列表数据
一.写在前面 说来还是比较惭愧的,从周二开始事就比较多,周三还电脑坏了,然后修电脑等等一些杂事,忙的团团转,因为周二.周三自己走的过多了,导致不敢直腰,周四卧床一天. 之前都听说<陈情令> ...
- px,dp sp是像素、尺寸、尺寸
px:即像素,1px代表屏幕上一个物理的像素点:px单位不被建议使用,因为同样100px的图片,在不同手机上显示的实际大小可能不同,如下图所示(图片来自android developer guide, ...
- Java:static关键字小记
Java:static关键字小记 对 Java 中的 static 关键字,做一个微不足道的小小小小记 static 修饰变量 静态变量:是被 static 修饰的变量,也称为类变量,它属于类,因此不 ...
- UltraSoft - Beta - Scrum Meeting 6
Date: May 22n'd, 2020. Scrum 情况汇报 进度情况 组员 负责 今日进度 q2l PM.后端 修复了DDL日程自动发邮件被服务器"吞掉"的bug后端增加了 ...