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_textget_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)的更多相关文章

  1. Django 小实例S1 简易学生选课管理系统 3 创建用户模型(model)

    Django 小实例S1 简易学生选课管理系统 第3节--创建用户模型(model) 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 本文涉及到的新 ...

  2. Django 小实例S1 简易学生选课管理系统 10 老师课程业务实现

    Django 小实例S1 简易学生选课管理系统 第10节--老师课程业务实现 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 课程模块中,老师将要使 ...

  3. Django 小实例S1 简易学生选课管理系统 12 CSS样式完善

    Django 小实例S1 简易学生选课管理系统 第12节--CSS样式完善 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 课程模块的逻辑代码到这里 ...

  4. Django 小实例S1 简易学生选课管理系统 11 学生课程业务实现

    Django 小实例S1 简易学生选课管理系统 第11节--学生课程业务实现 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 课程模块中,学生需要拥 ...

  5. Django 小实例S1 简易学生选课管理系统 8 CSS样式优化

    Django 小实例S1 简易学生选课管理系统 第8节--CSS样式优化 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 前面的几节下来,用户模块基 ...

  6. Django 小实例S1 简易学生选课管理系统 7 修改个人信息

    Django 小实例S1 简易学生选课管理系统 第7节--修改个人信息 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 用户模块除了注册登录之外,还 ...

  7. Django 小实例S1 简易学生选课管理系统 6 实现登录逻辑

    Django 小实例S1 简易学生选课管理系统 第6节--实现登录逻辑 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 1 业务逻辑 本教程第四节里 ...

  8. Django 小实例S1 简易学生选课管理系统 2 新建项目(project)并进行设置

    Django 小实例S1 简易学生选课管理系统 第2节--新建项目(project)并进行设置 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 0 ...

  9. Django 小实例S1 简易学生选课管理系统 4 实现登录页面

    Django 小实例S1 简易学生选课管理系统 第4节--实现登录页面 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 本文涉及到的新的额外知识点: ...

随机推荐

  1. 一、mybatis入门案例

    今天学习了mybatis框架,简单记录一下mybatis第一个入门案例,目标是使用Mybatis作为持久层框架,执行查询数据的SQL语句并且获取结果集 基本步骤: 物理建模 逻辑建模 引入依赖 创建持 ...

  2. CSP初赛考点汇总

    qwq 为SCP初赛选手(我)收集的各种定理qwq 更新: 1.为了初赛都能用,不限于定理了 2.主旨为在短时间内复习各算法,备初赛 3.请确定你学习(学懂了)了 \(\texttt{oi}\) 的基 ...

  3. Sentry 监控 - Snuba 数据中台架构简介(Kafka+Clickhouse)

    系列 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建版本 快速使用 Docker 上手 Sentry-CLI - 30 秒上手 Source Maps Sentry For ...

  4. app定位工具介绍

     一.元素获取工具WEditor使用   1.安装WEditor:pip3 install weditor   2.启动WEditor:python3 -m weditor    Android : ...

  5. 2020.10.30--vj个人赛补题

    D - D CodeForces - 743A Vladik is a competitive programmer. This year he is going to win the Interna ...

  6. Java:死锁编码及定位分析

    Java:死锁编码及定位分析 本笔记是根据bilibili上 尚硅谷 的课程 Java大厂面试题第二季 而做的笔记 概念 死锁是指两个或多个以上的进程在执行过程中,因争夺资源而造成一种互相等待的现象, ...

  7. 机器学习:EM算法

    EM算法 各类估计 最大似然估计 Maximum Likelihood Estimation,最大似然估计,即利用已知的样本结果,反推最有可能(最大概率)导致这样结果的参数值的计算过程. 直白来讲,就 ...

  8. SpringMvc 中 FrameworkServlet 覆盖 service 的有点。

    @Override protected void service(HttpServletRequest request, HttpServletResponse response) throws Se ...

  9. [软工顶级理解组] 团队规划和任务拆解(Beta)

    目录 需求再分析 功能增减 管理改进 任务分解 人员管理 需求再分析 在Alpha阶段,我们的产品得到了用户的广泛好评,但是还是存在一些问题. 登录不稳定,登录速度慢等问题:这是北航VPN本身的不稳定 ...

  10. Java 将Word保存为WPS和WPT格式

    本文通过Java示例展示将Word文档(如.doc/.docx)保存为WPS和WPT格式的方法. 程序环境配置 IntelliJ IDEA 2018(jdk 1.8.0) Word Jar包:Spir ...