mysql 学院_学院管理系统(mysql版)

from .models importTeacher,Class,Student,Lesson,Class_m2m_Lesson,Study_record,class_m2m_studentclassTeacher_Center(object):"讲师视图"

def __init__(self,session):

self.session=session

self.authentication()

self.handler()defhandler(self):whileTrue:print(‘‘‘\n\33[35;1m———欢迎来【%s】进入讲师管理系统————\33[0m \n

\33[34;0mshow_classes 显示可管理的班级

add_class 创建班级

add_student 添加学员

add_lesson 添加课程节次

add_studyrecord 创建上课记录

modify_scores 修改学员成绩

exit 退出管理系统

\33[0m‘‘‘ %self.teacher_obj.teacher_name)

user_func= input("\033[34;0m请输入进行操作的命令:\033[0m").strip()ifhasattr(self, user_func):

getattr(self, user_func)()defauthentication(self):‘‘‘认证‘‘‘

whileTrue:

teacher_name= input("\033[34;0m请输入讲师名:\033[0m").strip()

self.teacher_obj= self.session.query(Teacher).filter_by(teacher_name=teacher_name).first()if notself.teacher_obj:print("\33[31;1m输入错误:请输入有效的讲师名\33[0m")continue

else:#print(self.teacher_obj)

break

defadd_class(self):‘‘‘创建班级‘‘‘class_name= input("\033[34;0m请输入创建班级的名称:\033[0m")

course= input("\033[34;0m请输入创建班级的类型:\033[0m")

class_obj= self.session.query(Class).filter_by(class_name=class_name).first()if notclass_obj:

class_new= Class(class_name=class_name,course=course)

self.teacher_obj.classes.append(class_new)

self.session.add(class_new)

self.session.commit()print("\033[34;1m班级创建成功\033[0m")else:print("\33[31;1m系统错误:班级已经存在\33[0m")defshow_classes(self):‘‘‘查看所有的班级‘‘‘

print(self.teacher_obj)for class_obj inself.teacher_obj.classes:print("讲师:【%s】\t班级:【%s】\t类型:【%s】" %(class_obj.teachers[0].teacher_name,

class_obj.class_name,class_obj.course))defadd_student(self):‘‘‘添加学员‘‘‘class_name= input("\033[34;0m请输入要添加学员的班级名:\033[0m")

class_obj= self.session.query(Class).filter_by(class_name=class_name).first()if class_obj and class_obj.teachers[0] ==self.teacher_obj:

stu_name= input("\033[34;0m请输入学员的姓名:\033[0m")

QQ= input("\033[34;0m请输入学员的QQ号:\033[0m")

student_obj= self.session.query(Student).filter_by(QQ =QQ).first()ifstudent_obj:if student_obj.stu_name not inclass_obj.students:

class_obj.students.append(student_obj)

self.session.add(class_obj)

self.session.commit()print("\033[34;1m学员添加成功\033[0m")else:print("\33[31;1m系统错误:学员已经存在此班中\33[0m")elif notstudent_obj:

student_new= Student(stu_name=stu_name, QQ=QQ)

class_obj.students.append(student_new)

self.session.add(student_new)

self.session.commit()print("\033[34;1m学员添加成功\033[0m")else:print("\33[31;1m系统错误:学员已经存在\33[0m")else:print("\33[31;1m输入错误:班级不存在或没有权限管理此班级\33[0m")defadd_lesson(self):‘‘‘添加课程节次‘‘‘class_name= input("\033[34;0m请输入要添加lesson的班级名:\033[0m")

class_obj= self.session.query(Class).filter_by(class_name=class_name).first()if class_obj and class_obj.teachers[0] == self.teacher_obj: #输入的班级名存在且在属于当前老师管理

lesson_name = input("\033[34;0m请输入添加的lesson名(类day1):\033[0m")

lesson_obj= self.session.query(Lesson).filter_by(lesson_name=lesson_name).first()if not lesson_obj: #输入的lesson名字不存在

print("lesson 不存在")

lesson_obj= Lesson(lesson_name=lesson_name) #增加lesson表数据

self.session.add(lesson_obj)

self.session.commit()

rest= self.session.query(Class_m2m_Lesson).filter(Class_m2m_Lesson.class_id==class_obj.class_id). filter(Class_m2m_Lesson.lesson_id==lesson_obj.lesson_id).first()if not rest: #如果class_m2m_lesson没有存储班级和课节的对应关系

print("class:%s----lesson:%s"%(class_obj.class_id,lesson_obj.lesson_id))

class_m2m_lesson_new= Class_m2m_Lesson(class_id=class_obj.class_id,lesson_id=lesson_obj.lesson_id)

self.session.add(class_m2m_lesson_new)#创建class_m2m_lesson对应关系

self.session.commit()else:print("\33[31;1m输入错误:班级不存在或没有权限管理此班级\33[0m")defadd_studyrecord(self):‘‘‘添加学习记录‘‘‘class_name= input("\033[34;0m请输入要添加学习记录的班级名:\033[0m")

class_obj= self.session.query(Class).filter_by(class_name=class_name).first()if class_obj and class_obj.teachers[0] == self.teacher_obj: #输入的班级名存在且在属于当前老师管理

lesson_name = input("\033[34;0m请输入添加学习记录的课节名(lesson):\033[0m")

lesson_obj= self.session.query(Lesson).filter_by(lesson_name=lesson_name).first()if lesson_obj: #输入的lesson名字存在

class_m2m_lesson_obj = self.session.query(Class_m2m_Lesson).filter(Class_m2m_Lesson.class_id ==class_obj.class_id). filter(Class_m2m_Lesson.lesson_id==lesson_obj.lesson_id).first()if class_m2m_lesson_obj: #班级对应的课lesson表数据存在

study_record_obj= self.session.query(Study_record).filter_by(class_m2m_lesson_id=class_m2m_lesson_obj.id).first()if not study_record_obj: #上课记录为创建

for student_obj inclass_obj.students:

status= input("输入学生 %s 的上课状态(yes/no):"%student_obj.stu_name)

study_record_new= Study_record(class_m2m_lesson_id=class_m2m_lesson_obj.id,

stu_id=student_obj.stu_id,

status=status)

self.session.add(study_record_new)

self.session.commit()else:print("\33[31;1m系统错误:当前上课记录已经创建\33[0m")else:print("\33[31;1m系统错误:当前班级的lesson课节未创建\33[0m")else:print("\33[31;1m系统错误:lesson未创建\33[0m")else:print("\33[31;1m输入错误:班级不存在或没有权限管理此班级\33[0m")defmodify_scores(self):‘‘‘修改成绩‘‘‘class_name= input("\033[34;0m请输入学习记录的班级名:\033[0m")

class_obj= self.session.query(Class).filter_by(class_name=class_name).first()if class_obj and class_obj.teachers[0] == self.teacher_obj: #输入的班级名存在且在属于当前老师管理

lesson_name = input("\033[34;0m请输入学习记录的课节名(lesson):\033[0m")

lesson_obj= self.session.query(Lesson).filter_by(lesson_name=lesson_name).first()if lesson_obj: #输入的lesson名字存在

class_m2m_lesson_obj =self.session.query(Class_m2m_Lesson).filter(

Class_m2m_Lesson.class_id==class_obj.class_id). filter(Class_m2m_Lesson.lesson_id==lesson_obj.lesson_id).first()if class_m2m_lesson_obj: #班级对应的课lesson表数据存在

whileTrue:

study_record_objs=self.session.query(Study_record).filter(

Study_record.class_m2m_lesson_id==class_m2m_lesson_obj.id).all()for obj instudy_record_objs:print(obj)

student_name= input("\033[34;0m输入要修改成绩的学生名:[Q 退出]\33[0m")if student_name == "q" or student_name == "Q":breakstudent_obj= self.session.query(Student).filter_by(stu_name=student_name).first()ifstudent_obj:

study_record_obj=self.session.query(Study_record).filter(

Study_record.class_m2m_lesson_id==class_m2m_lesson_obj.id).filter(

Study_record.stu_id==student_obj.stu_id).first()if study_record_obj: #上课记录存在

score = input("\033[34;0m输入修改后的成绩\33[0m")

study_record_obj.score=score

self.session.commit()else:print("\33[31;1m系统错误:当前上课记录已经创建\33[0m")else:print("\33[31;1m系统错误:当前班级的lesson课节未创建\33[0m")else:print("\33[31;1m系统错误:lesson未创建\33[0m")else:print("\33[31;1m输入错误:班级不存在或没有权限管理此班级\33[0m")defexit(self):

exit()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值