Python选课系统开发程序

发表于 5年以前  | 总阅读数:1194 次

本文程序针对Python选课系统进行开发,供大家参考,具体内容如下

角色:学校、学员、课程、讲师
要求:
1. 创建北京、上海 2 所学校
2. 创建linux , python , go 3个课程 , linux\py 在北京开, go 在上海开
3. 课程包含,周期,价格,通过学校创建课程
4. 通过学校创建班级, 班级关联课程、讲师
5. 创建学员时,选择学校,关联班级
5. 创建讲师角色时要关联学校,
6. 提供两个角色接口
7. 学员视图, 可以注册, 交学费, 选择班级,
8. 讲师视图, 讲师可管理自己的班级, 上课时选择班级, 查看班级学员列表 , 修改所管理的学员的成绩
9. 管理视图,创建讲师, 创建班级,创建课程
10. 上面的操作产生的数据都通过pickle序列化保存到文件里

程序:

1、最最重要的readme:

作者介绍:

  • author:lzl

    博客地址:

  • http://www.cnblogs.com/lianzhilei/p/5813986.html

功能实现

1\. 创建北京、上海 2 所学校  
2\. 创建linux , python , go 3个课程 , linux\py 在北京开, go 在上海开  
3\. 课程包含,周期,价格,通过学校创建课程  
4\. 通过学校创建班级, 班级关联课程、讲师  
5\. 创建学员时,选择学校,关联班级  
5\. 创建讲师角色时要关联学校,  
6\. 提供两个角色接口  
6.1 学员视图, 可以注册, 交学费, 选择班级,  
6.2 讲师视图, 讲师可管理自己的班级, 上课时选择班级, 查看班级学员列表 , 修改所管理的学员的成绩  
6.3 管理视图,创建讲师, 创建班级,创建课程  
7\. 上面的操作产生的数据都通过pickle序列化保存到文件里  
(所有功能均实现)

程序需知

1\. 当前数据库已建立好信息,可以直接进行查看增加  
    北京  课程:Python   讲师:金角大王     班级:S14      学员:我要学python  
          课程:Linux    讲师:银角大王     班级:L01      学员:我要学Linux  
    上海  课程:Go       讲师:天棚元帅     班级:G01      学员:我要学GO  
2\. 也可以把database下的两个数据库文件删除掉,数据清空,执行程序,数据库进行初始化,初始化只生成北京、上海学校名  
3\. 数据库结构main_dict 储存主要的逻辑结构:  
    {学校名:{课程名1:{"teacher":讲师,"grade":班级},课程名2:{"teacher":讲师2,"grade":班级2}},  
    学校名:{课程名3:{"teacher":讲师3,"grade":班级3},课程名4:{"teacher":讲师4,"grade":班级4}}}  
    存储的数据类型都为实例对象  
   数据库结构teacher_dict 存储讲师与班级的对应关系,用于方便讲师登录系统认证,结构为  
    {讲师:{grade:班级}  
    两个数据库文件均可扩展  
4\. 程序实现了以下严格限制:  
   ①一个学校里面不能出现同名的课程  
   ②一个课程只能有一个讲师  
   ③讲师被聘用后,不能再进行聘用,一个讲师也只能教一门课程(教python,就不能再教linux了)  
   ④班级只能对应一门课程,班级名只能出现一次,不能重复(python班级s14,linux的班级就不能再出现s14班级了)

后期扩展

 程序没有定义学生类,后期可定义类,添加学生属性(年龄,成绩),对可学生成绩信息进行修改,把功能添加到教师中心,很显然  
 我没时间了。。。。。  
 程序按功能分出不同的模块,可以更简洁

2、程序目录结构:

3、数据库:

main_dict和teacher_dict两个数据库文件可不创建,运行程序自动生成

4、程序main.py


    #!/usr/bin/env python
    # -*- coding:utf-8 -*-
    #-Author-Lian 

    import pickle,os
    BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
    #数据地址
    __db_main = BASE_DIR + r"\database\main_dict"
    __db_teacher = BASE_DIR + r"\database\teacher_dict"

    class School(object):
     #创建学校

     def __init__(self,name,addr):

     self.name = name

     self.addr = addr

     def cat_school(self):
     print("学校名:【%s】\t地址:【%s】"%(self.name,self.addr))


     def hire_teacher(self,dict,course,teacher,file):
     #数据库添加讲师信息
     dict[self][course] = {"teacher":teacher}
     file_oper(file,"wb", dict)

     def create_course(self,dict,course,file):
     # 数据库添加课程资料
     dict[self][course]={}
     file_oper(file,"wb", dict)
     def create_grade(self,dict,teacher_dict,course,grade,teacher,file1,file2):
     #数据库添加班级信息
     dict[self][course]["grade"] = grade
     file_oper(file1, "wb", dict)
     teacher_dict[teacher] = {"grade":grade}
     file_oper(file2, "wb", teacher_dict)

    class Course():
     #创建课程
     def __init__(self,name,price,time):
     self.name = name
     self.price = price
     self.time = time
     def cat_course(self):
     #查看课程信息
     print("课程:【%s】\t价格:【¥%s】\t周期:【%s个月】"
      %(self.name,self.price,self.time))

    class Grade():
     # 创建班级
     def __init__(self,name,course,teacher):
     student = set([])
     self.name = name
     self.course = course
     self.teacher = teacher
     self.student = student



     def cat_grade(self):
     #查看班级信息
     print("班级:【%s】\t课程:【%s】\t讲师:【%s】"
      %(self.name, self.course, self.teacher))



     def add_student(self,student_name,dict,teacher,file):
     self.student.add(student_name)
     dict[teacher]={"grade":self}
     file_oper(file, "wb", dict)

    class People():
     def __init__(self,name,age):
     self.name = name
     self.age = age
    class Teacher(People):
     # 创建讲师
     def __init__(self,name,age,school,course,role="讲师"):
     super(Teacher,self).__init__(name,age)
     self.role = role
     self.school = school
     self.course = course
     def cat_teacher(self):
     #查看老师资料和课程
     print('课程【%s】\t讲师【%s】'%(self.course,self.name))


    def file_oper(file,mode,*args):

     #数据库写入、读取操作

     if mode == "wb":
     with open(file, mode) as f:
      dict = args[0]
      f.write(pickle.dumps(dict))

     if mode == "rb":
     with open(file, mode) as f:
      dict = pickle.loads(f.read())
      return dict

    def information(dict,mode,*args):

     '''通过匹配mode模式,打印相应的输出信息'''
     if args:
     dict_info, set_info = {}, args[0]
     else:
     dict_info,set_info = {},set([])
     if dict:
     for key in dict:
      if mode == "course":
      key.cat_course()
      if mode == "main":
      key.cat_school()
      if mode == "teacher" and key == "teacher":
      dict[key].cat_teacher()
      # dict_info[key] = dict[key]
      set_info.add(dict[key].name)
      if mode == "grade" and key == "grade":
      dict[key].cat_grade()
      set_info.add(dict[key].name)
      if mode == "teacher_center":
      pass
      if type(key) != str: #key值不是字符串
      dict_info[key.name] = key
     return dict_info,set_info



    def school_center():

     #学校管理中心

     Flag = True

     while Flag:
     dict_main = file_oper(__db_main,"rb") #主字典
     res_dict = information(dict_main,"main")[0] #打印学校信息
     school_name = input("\33[34;0m输入要选择的学校名\33[0m:").strip()
     if school_name in res_dict:
      school = res_dict[school_name]  #匹配选择的学校
      while Flag:
      print("\33[32;1m欢迎进入【%s】学校\33[0m".center(50, "*")%school.name)
      choice = options(list_school) #打印当前选项
      if choice == "1":
       while True:
       print("\33[32;0m学校【%s】目前已经有的班级信息\33[0m".center(40, "-")%school.name)
       teacher_dict = file_oper(__db_teacher,"rb")
       res_course = information(dict_main[school], "None")[0]
       set_info = set([])
       if res_course: # 打印课程与讲师对应关系
        for i in res_course:
        k = res_course[i]
        res_grade = information(dict_main[school][k], "grade",set_info)[1]
       if_cont = input("\n\33[34;0m是否要创建班级 【y】创建 【b】退出\33[0m:")
       if if_cont == "y":
        grade_name = input("\33[34;0m输入要创建班级的名称\33[0m:").strip()
        course_name = input("\33[34;0m输入要班级要上的课程\33[0m:").strip()
        if course_name in res_course:
        course = res_course[course_name]
        if dict_main[school][course]:
         teacher = dict_main[school][course]["teacher"]
         if grade_name not in res_grade:
         grade = Grade(grade_name, course_name, teacher.name)
         school.create_grade(dict_main, teacher_dict, course, grade, teacher, __db_main,
           __db_teacher)
         else:

         print("\33[31;0m错误:当前班级已经存在\33[0m")

        else:

         print("\33[31;0m错误:当前课程还没有讲师\33[0m")

        else:

        print("\33[31;0m错误:课程【%s】不存在,请先创建课程\33[0m" % course_name)
       if if_cont == "b":
        break

      if choice == "2":
       #招聘讲师
       while True:
       print("\33[32;0m学校【%s】目前已经有的课程与讲师\33[0m".center(40, "-")%school.name)
       res_course = information(dict_main[school],"None")[0]
       set_info = set([])
       if res_course:   #打印课程与讲师对应关系
        for i in res_course:
        k = res_course[i]
        res_teacher = information(dict_main[school][k], "teacher",set_info)[1]
        if not res_teacher:
         print("课程【%s】\t讲师【None】" %(i))

       if_cont = input("\n\33[34;0m是否要招聘讲师 【y】招聘 【b】退出\33[0m:")
       if if_cont == "y":
        teacher_name = input("\33[34;0m输入要招聘讲师的名字\33[0m:").strip()
        teacher_age = input("\33[34;0m输入要招聘讲师的年龄\33[0m:").strip()
        course_name = input("\33[34;0m输入讲师【%s】要授课的课程\33[0m:"%teacher_name).strip()
        if course_name in res_course:
         course = res_course[course_name] #创建讲师并写入数据库
         if teacher_name not in res_teacher:
         teacher = Teacher(teacher_name,teacher_age,school.name,course_name)
         school.hire_teacher(dict_main, course, teacher, __db_main)
         else:
         print("\33[31;0m错误:教师【%s】已经被聘用\33[0m" %teacher_name)
        else:
        print("\33[31;0m错误:课程【%s】不存在,请先创建课程\33[0m" %course_name)
       if if_cont == "b":
        break
      if choice == "3":
       #创建课程
       while True:
       print("\33[32;0m学校【%s】目前已经有的课程\33[0m".center(40,"-")%school.name)
       res_dict = information(dict_main[school],"course")[0] #打印课程信息赋值给字典course_dict
       if_cont = input("\n\33[34;0m是否要创建课程 【y】创建 【b】退出\33[0m:")
       if if_cont == "y":
        course_name = input("\33[34;0m输入要创建的课程\33[0m:").strip()
        if course_name not in res_dict: #课程不存在,创建
        price = input("\33[34;0m输入课程 【%s】 的价格\33[0m:" % (course_name))
        time = input("\33[34;0m输入课程 【%s】 的周期(月)\33[0m:" % (course_name))
        course = Course(course_name, price, time) #创建课程course
        school.create_course(dict_main,course, __db_main) #关联学校和课程
        else:     #课程存在
        print("\33[31;0m错误:当前课程 【%s】 已经存在\33[0m" % (course_name))
       if if_cont == "b":
        break


      if choice == "4":
       Flag = False
     if Flag:
      print("\33[31;0m错误:输入的学校 【%s】 不存在\33[0m"%(school_name))
    def teacher_center():

     #讲师中心

     print("\33[32;1m欢迎进入讲师中心\33[0m".center(50, "*"))
     teacher_dict = file_oper(__db_teacher, "rb")

     dict_info = information(teacher_dict,"teacher_center")[0] #验证登录

     teacher_name = input("\n\33[34;0m输入要登录讲师的名字\33[0m:").strip()

     if teacher_name in dict_info:
      while True:
      print("\33[32;1m欢迎进入讲师【%s】的管理中心\33[0m".center(40, "*")%teacher_name)
      choice = options(list_teacher)
      teacher = dict_info[teacher_name]
      grade = teacher_dict[teacher]["grade"]
      if choice == "1":
       print("\33[32;0m讲师【%s】的班级信息\33[0m".center(40,"-")%teacher.name)
       print("学校【%s】\t课程【%s】\t班级【%s】\t"%(teacher.school,teacher.course,grade.name))
       any = input("\n\33[34;0m输入任意键退出当前\33[0m:")
      if choice == "2":
       print("\33[32;0m讲师【%s】的班级学员列表\33[0m".center(40, "-") % teacher.name)
       print("班级【%s】\n学员【%s】"%(grade.name,grade.student))
       any = input("\n\33[34;0m输入任意键退出当前\33[0m:")
      if choice == "3":
       break
     else:
      print("\33[31;0m错误:讲师【%s】 不存在\33[0m"%(teacher_name))
    def student_center():
     #学员中心
     print("\33[32;1m欢迎进入学员中心中心\33[0m".center(50, "*"))
     while True:
     choice = options(list_student)  #打印学生中心选项
     if choice == "1":
      student_name = input("\33[34;0m输入学员的名字\33[0m:")
      dict = file_oper(__db_main, "rb")
      teacher_dict = file_oper(__db_teacher,"rb")
      school_dict = information(dict,"main")[0] #打印当前可选的学校
      school_name = input("\33[34;0m输入要选择的学校名\33[0m:").strip()
      if school_name in school_dict:
      school = school_dict[school_name]
      if dict[school]:
       course_dict = information(dict[school],"course")[0] # 打印当前学校下的课程
       course_name = input("\33[34;0m输入要选择的课程\33[0m:").strip()
       if course_name in course_dict:
       course = course_dict[course_name]
       if dict[school][course].get("grade"):
        for i in teacher_dict:
        if course.name == i.course:
         teacher = i
         grade = teacher_dict[teacher]["grade"]
        print("课程【%s】的费用为【%s】"%(course.name,course.price))
        if_pay = input("\33[34;0m是否支付当前费用 支付【y】\33[0m:")
        if if_pay == "y":  #上面全部匹配成功,选课成功
        grade.add_student(student_name,teacher_dict,teacher,__db_teacher)
        print("\33[31;0m选课成功\33[0m")
        any = input("\n\33[34;0m输入任意键退出当前\33[0m:")
       else:
        print("\33[31;0m错误:课程没有班级\33[0m")
       else:
       print("\33[31;0m错误:课程不存在\33[0m")
      else:
       print("\33[31;0m错误:当前学校没有课程\33[0m")
     if choice == "2":
      break

    def options(list):
     #打印可选择的操作模式,并返回选择值
     for i, v in enumerate(list):
     print(i+1, v)
     choice = input("\33[34;0m选择要进入模式\33[0m:")
     return choice 

    def start():
     '''程序开始'''
     while True:
     print("\33[35;1m欢迎进入选课系统\33[0m".center(50, "#"))
     choice = options(list_main) #打印选项
     if choice == "1":
      student_center() #学生中心
     if choice == "2":
      teacher_center() #教师中心
     if choice == "3":
      school_center()  #学校中心
     if choice == "4":
      break

    def init_database():
     '''数据库初始化,不存在则创建,存在跳过'''
     bj = School("北京","北京市")
     sh = School("上海","上海市")
     if not os.path.exists(__db_teacher):
     dict = {bj:{},sh:{}}
     file_oper(__db_main,"wb",dict)
     if not os.path.exists(__db_teacher):
     dict = {}
     file_oper(__db_teacher,"wb",dict)

    if __name__ == '__main__':
     init_database() #初始化数据库
     list_main = ["学生中心", "讲师中心", "学校中心","退出"]
     list_school = ["创建班级", "招聘讲师", "创建课程","返回"]
     list_teacher = ["查看班级", "查看班级学员列表","返回" ]
     list_student = ["学员注册","返回"]
     start()

5、程序运行过程的简略图

*学生中心***

*讲师中心***

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

 相关推荐

刘强东夫妇:“移民美国”传言被驳斥

京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。

发布于:1年以前  |  808次阅读  |  详细内容 »

博主曝三大运营商,将集体采购百万台华为Mate60系列

日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。

发布于:1年以前  |  770次阅读  |  详细内容 »

ASML CEO警告:出口管制不是可行做法,不要“逼迫中国大陆创新”

据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。

发布于:1年以前  |  756次阅读  |  详细内容 »

抖音中长视频App青桃更名抖音精选,字节再发力对抗B站

今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。

发布于:1年以前  |  648次阅读  |  详细内容 »

威马CDO:中国每百户家庭仅17户有车

日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。

发布于:1年以前  |  589次阅读  |  详细内容 »

研究发现维生素 C 等抗氧化剂会刺激癌症生长和转移

近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。

发布于:1年以前  |  449次阅读  |  详细内容 »

苹果据称正引入3D打印技术,用以生产智能手表的钢质底盘

据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。

发布于:1年以前  |  446次阅读  |  详细内容 »

千万级抖音网红秀才账号被封禁

9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...

发布于:1年以前  |  445次阅读  |  详细内容 »

亚马逊股东起诉公司和贝索斯,称其在购买卫星发射服务时忽视了 SpaceX

9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。

发布于:1年以前  |  444次阅读  |  详细内容 »

苹果上线AppsbyApple网站,以推广自家应用程序

据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。

发布于:1年以前  |  442次阅读  |  详细内容 »

特斯拉美国降价引发投资者不满:“这是短期麻醉剂”

特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。

发布于:1年以前  |  441次阅读  |  详细内容 »

光刻机巨头阿斯麦:拿到许可,继续对华出口

据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。

发布于:1年以前  |  437次阅读  |  详细内容 »

马斯克与库克首次隔空合作:为苹果提供卫星服务

近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。

发布于:1年以前  |  430次阅读  |  详细内容 »

𝕏(推特)调整隐私政策,可拿用户发布的信息训练 AI 模型

据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。

发布于:1年以前  |  428次阅读  |  详细内容 »

荣耀CEO谈华为手机回归:替老同事们高兴,对行业也是好事

9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。

发布于:1年以前  |  423次阅读  |  详细内容 »

AI操控无人机能力超越人类冠军

《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。

发布于:1年以前  |  423次阅读  |  详细内容 »

AI生成的蘑菇科普书存在可致命错误

近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。

发布于:1年以前  |  420次阅读  |  详细内容 »

社交媒体平台𝕏计划收集用户生物识别数据与工作教育经历

社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”

发布于:1年以前  |  411次阅读  |  详细内容 »

国产扫地机器人热销欧洲,国产割草机器人抢占欧洲草坪

2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。

发布于:1年以前  |  406次阅读  |  详细内容 »

罗永浩吐槽iPhone15和14不会有区别,除了序列号变了

罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。

发布于:1年以前  |  398次阅读  |  详细内容 »
 相关文章
Android插件化方案 5年以前  |  237152次阅读
vscode超好用的代码书签插件Bookmarks 1年以前  |  7934次阅读
 目录