Python选课系统开发程序


Posted in Python onSeptember 02, 2016

本文程序针对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、程序目录结构: 

Python选课系统开发程序

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、程序运行过程的简略图

Python选课系统开发程序

Python选课系统开发程序

*********************学生中心***********************

Python选课系统开发程序

*********************讲师中心***********************

Python选课系统开发程序

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

Python 相关文章推荐
Python 列表排序方法reverse、sort、sorted详解
Jan 22 Python
python 默认参数问题的陷阱
Feb 29 Python
win与linux系统中python requests 安装
Dec 04 Python
神经网络理论基础及Python实现详解
Dec 15 Python
python实现画五角星和螺旋线的示例
Jan 20 Python
Python远程视频监控程序的实例代码
May 05 Python
利用Django模版生成树状结构实例代码
May 19 Python
Python实现微信中找回好友、群聊用户撤回的消息功能示例
Aug 23 Python
使用pygame写一个古诗词填空通关游戏
Dec 03 Python
使用Python制作新型冠状病毒实时疫情图
Jan 28 Python
python如何构建mock接口服务
Jan 28 Python
python3+PyQt5+Qt Designer实现界面可视化
Jun 10 Python
简单谈谈Python中函数的可变参数
Sep 02 #Python
Python实现自动添加脚本头信息的示例代码
Sep 02 #Python
利用Python获取操作系统信息实例
Sep 02 #Python
好用的Python编辑器WingIDE的使用经验总结
Aug 31 #Python
Linux下为不同版本python安装第三方库
Aug 31 #Python
Python中的左斜杠、右斜杠(正斜杠和反斜杠)
Aug 30 #Python
分享Python开发中要注意的十个小贴士
Aug 30 #Python
You might like
服务器web工具 php环境下
2010/12/29 PHP
php获得url参数中具有&的值的方法
2014/03/05 PHP
ThinkPHP之A方法实例讲解
2014/06/20 PHP
php结合curl实现多线程抓取
2015/07/09 PHP
php实现在多维数组中查找特定value的方法
2015/07/29 PHP
JavaScript计算字符串中每个字符出现次数的小例子
2013/07/02 Javascript
js简单实现删除记录时的提示效果
2013/12/05 Javascript
如何在指定的地方插入html内容和文本内容
2013/12/23 Javascript
jquery判断元素是否隐藏的多种方法
2014/05/06 Javascript
node中socket.io的事件使用详解
2014/12/15 Javascript
js实现键盘Enter键提交表单的方法
2015/05/27 Javascript
JS实现自定义简单网页软键盘效果代码
2015/11/05 Javascript
手机图片预览插件photoswipe.js使用总结
2016/08/25 Javascript
浅析如何利用angular结合translate为项目实现国际化
2016/12/08 Javascript
微信小程序中button组件的边框设置的实例详解
2017/09/27 Javascript
利用HBuilder打包前端开发webapp为apk的方法
2017/11/13 Javascript
vue中倒计时组件的实例代码
2018/07/06 Javascript
python打开网页和暂停实例
2014/09/30 Python
python定时器(Timer)用法简单实例
2015/06/04 Python
Python实现在线暴力破解邮箱账号密码功能示例【测试可用】
2017/09/06 Python
Python使用numpy产生正态分布随机数的向量或矩阵操作示例
2018/08/22 Python
python实现石头剪刀布小游戏
2021/01/20 Python
Python3+PyInstall+Sciter解决报错缺少dll、html等文件问题
2019/07/15 Python
新奇的小玩意:IWOOT
2016/07/21 全球购物
全球领先的各类汽车配件零售商:Advance Auto Parts
2016/08/26 全球购物
购买瑞典当代设计的腕表和太阳眼镜:TRIWA
2016/10/30 全球购物
全球销量第一生发产品:Viviscal
2017/12/21 全球购物
市场营销专业个人自荐信格式
2013/09/21 职场文书
成功的酒店创业计划书
2013/12/27 职场文书
信息专业学生学习的自我评价
2014/02/17 职场文书
《陶罐和铁罐》教学反思
2014/02/19 职场文书
教师廉政准则心得体会
2016/01/20 职场文书
基于python实现银行管理系统
2021/04/20 Python
MySQL 那些常见的错误设计规范,你都知道吗
2021/07/16 MySQL
java设计模式--三种工厂模式详解
2021/07/21 Java/Android
JavaScript 对象创建的3种方法
2021/11/17 Javascript