实现一个python选课系统实例

  下面介绍一下自己写的python程序,主要是的知识点为sys、os、json、pickle的模块应用,python程序包的的使用,以及关于类的使用。

  下面是我的程序目录:

          实现一个python选课系统实例

bin是存放一些执行文件course.py下面是这个文件的内容:

import sys,os#程序主目录BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))print(BASE_DIR)#添加环境变量sys.path.append(BASE_DIR)from core import mainif __name__ == '__main__':    a =main.Run()    a.interactive()

这个文件是对os,sys模块的应用;

立即学习“Python免费学习笔记(深入)”;

BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

  这里的os.path.abspath(__file__)是查看当前文件的所在位置。例如:

  D:python项目选课系统course_systembincourse.py

  这里的os.path.abspath是上一级目录例如:print(BASE_DIR)

  D:python项目选课系统course_system

sys.path.append(BASE_DIR) 括号里面是模块引用的地址,我们可以理解把这个模块得知设置成环境变量。from core import main  导入core包中的main文件这里是core包中udi.py文件
import hashlibimport timedef create_md():    m = hashlib.md5()    m.update(bytes(str(time.time()),encoding="utf-8"))    return m.hexdigest()

在python中hashlib提供了常见的摘要算法,如MD5,SHA1等等。它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制的字符串表示)。为了给学生生成一个随机不重复的uid。

 

这里是core包中main.py文件内容

import sys,os         import json      #这里说一下json这个模块,java之中也有应用,所以一些数据也可以给java去用。import pickle     from bin import coursefrom core import uid#数据库文件路径db_DIR = course.BASE_DIR + r"db"db_school = db_DIR + r"school"db_teacher = db_DIR + r"teacher"db_student = db_DIR + r"student"db_classes = db_DIR + r"classes"db_course = db_DIR + r"course"db_admin = db_DIR + r"admin"db_class_record = db_DIR + r"class_record"db_class_grade = db_DIR + r"class_grade"#基础类,主要包括文件的读写操作class Baseclass(object):  #在python3中全部是新式类,但是建议还是这样写。在python2中存在经典类和新式类;例如:class Baseclass: 这种在python中是经典类,而class Baseclass(object):这样是新式类。有关它们的区别,我会在下一篇博客中具体说明。    def __init__(self):        pass    def save(self,type,dict):        filename = uid.create_md()        dict['uid'] = filename        file_path = "%s%s" %(db_DIR,type)        ab_file = "%s%s" %(file_path,filename)        if os.path.isdir(file_path):            with open(ab_file,"wb") as f:                f.write(pickle.dumps(dict))                if True:                    print(                    "-------",type,"创建成功","-------")                    for key in dict:                        print(key,":t",dict[key])    def seek_list(self,type,list):        filename = uid.create_md()        file_path = "%s%s" %(db_DIR,type)        ab_file = "%s%s" %(file_path,filename)        if os.path.isdir(file_path):            with open(ab_file,"wb") as f:                f.write(pickle.dumps(list))                if True:                    print(                    "-------",type,"创建成功","-------")                    for i in list:                        for key in i:                            print(key,i[key])                        print("n")        return True    def open(self,type):        all_data = []        db_path = "%s%s" %(db_DIR,type)        for i in os.listdir(db_path):            if os.path.isfile(os.path.join(db_path,i)):                db_file = os.path.join(db_path,i)                with open(db_file,"rb") as f:                    file_dict = pickle.load(f)                    all_data.append(file_dict)        return all_data#admin类class Admin(Baseclass):    def __init__(self):        Baseclass.__init__(self)    def create_school(self):        school_dict = {}        school_name = input("校名:")        school_address = input("地址:")        s1 = School(school_name, school_address)        school_dict["校名"] = s1.school_name        school_dict["地址"] = s1.school_address        Baseclass.save(self, "school", school_dict)    def create_teacher(self):        teacher_dict = {}        teacher_name = input("讲师姓名:")        teacher_salary = input("讲师工资:")        teacher_school = input("所属学校:")        t1 = Teacher(teacher_name, teacher_salary, teacher_school)        teacher_dict["姓名"] = t1.teacher_name        teacher_dict["工资"] = t1.teacher_salary        teacher_dict["所属学校"] = t1.teacher_school        print(teacher_dict)        Baseclass.save(self, "teacher", teacher_dict)    def create_student(self):        student_dict = {}        student_name = input("学员姓名:")        student_sex = input("学员性别:")        student_school = input("所属学校:")        student_classes = input("学员班级:")        st1 = Student(student_name, student_sex, student_school, student_classes)        student_dict["姓名"] = st1.student_name        student_dict["性别"] = st1.student_sex        student_dict["学校"] = st1.student_school        student_dict["班级"] = st1.student_classes        Baseclass.save(self, "student", student_dict)    def create_course(self):        course_dict = {}        course_name = input("课程名:")        course_period = input("周期:")        course_prices = input("价格:")        c1 = Course(course_name, course_period, course_prices)        course_dict["课程名"] = c1.course_name        course_dict["周期"] = c1.course_period        course_dict["价格"] = course_prices        Baseclass.save(self, "course", course_dict)    def create_classes(self):        classes_dict = {}        classes_name = input("班级名:")        classes_teachter = input("负责讲师:")        classes_course = input("所学课程:")        cs1 = Classes(classes_name, classes_teachter, classes_course)        classes_dict["班级名"] = cs1.classes_name        classes_dict["负责讲师"] = cs1.classes_teacher        classes_dict["课程"] = cs1.classes_course        Baseclass.save(self, "classes", classes_dict)#School类class School(Baseclass):    def __init__(self,school_name,school_address):        Baseclass.__init__(self)        self.school_name = school_name        self.school_address = school_address#teacher类class Teacher(Baseclass):    def __init__(self,teacher_name,teacher_salary,teacher_school):        Baseclass.__init__(self)        self.teacher_name = teacher_name        self.teacher_salary = teacher_salary        self.teacher_school = teacher_school    def create_class_record(self):        class_record = []        student_school = input("选择学校:")        student_classes = input("选择班级:")        student_times = input("课次:")        student_list = Baseclass.open(self,"student")        for i in student_list:            if i["学校"] == student_school and i["班级"] == student_classes:                student_name = i["姓名"]                student_status = input("%s 上课情况:" % student_name)                i["上课情况"] = student_status                i["课次"] = student_times                class_record.append(i)        Baseclass.seek_list(self,"class_record",class_record)    def create_class_grade(self):        class_grade = []        student_school = input("选择学校:")        student_classes = input("选择班级:")        student_times = input("课次:")        student_list = Baseclass.open(self,"student")        for i in student_list:            if i["学校"] == student_school and i["班级"] == student_classes:                student_name = i["姓名"]                student_grade = input("%s 成绩:" % student_name)                i["成绩"] = student_grade                i["课次"] = student_times                class_grade.append(i)        Baseclass.seek_list(self,"class_grade",class_grade)    def teacher_view_grade(self):        grade_list = []        student_school = input("校名:")        student_class = input("班级:")        student_times = input("课次:")        class_grade_list = Baseclass.open(self, "class_grade")        for i in class_grade_list:            for j in i:                if j["学校"] == student_school and j["班级"] == student_class and j["课次"] == student_times:                    grade_list.append(j)        for i in grade_list:            for key in i:                print(key,i[key])            print("n")    def tacher_view_record(self):        record_list = []        student_school = input("校名:")        student_class = input("班级:")        student_times = input("课次:")        class_record_list = Baseclass.open(self, "class_record")        for i in class_record_list:            for j in i:                if j["学校"] == student_school and j["班级"] == student_class and j["课次"] == student_times:                    record_list.append(j)        for i in record_list:            for key in i:                print(key,i[key])            print("n")#classes类class Course(Baseclass):    def __init__(self,course_name,course_period,course_prices):        Baseclass.__init__(self)        self.course_name = course_name        self.course_period = course_period        self.course_prices = course_prices#student类class Student(Baseclass):    def __init__(self,student_name,student_sex,student_school,student_classes):        Baseclass.__init__(self)        self.student_name = student_name        self.student_sex = student_sex        self.student_school = student_school        self.student_classes = student_classes    def student_registered(self):        student_dict = {}        print("欢迎进入学生注册系统")        student_name = input("注册姓名:")        student_sex = input("性别:")        student_school = input("学校:")        student_class = input("班级:")        st1 = Student(student_name,student_sex,student_school,student_class)        student_dict["姓名"] = st1.student_name        student_dict["性别"] = st1.student_sex        student_dict["学校"] = st1.student_school        student_dict["班级"] = st1.student_classes        Baseclass.save(self, "student", student_dict)    def student_pay_fees(self):        pass    def student_view_grade(self):        student_school = input("校名:")        student_class = input("班级:")        student_times = input("课次:")        student_name = input("姓名:")        class_grade_list = Baseclass.open(self,"class_grade")        for i in class_grade_list:            for j in i:                if j["学校"] == student_school and j["班级"] == student_class and j["课次"] == student_times                     and j["姓名"] == student_name:                    for key in j:                        print(key,j[key])                    print("n")    def student_view_record(self):        student_school = input("校名:")        student_class = input("班级:")        student_times = input("课次:")        student_name = input("姓名:")        class_record_list = Baseclass.open(self,"class_record")        for i in class_record_list:            for j in i:                if j["学校"] == student_school and j["班级"] == student_class and j["课次"] == student_times                     and j["姓名"] == student_name:                    for key in j:                        print(key,j[key])                    print("n")#课程类class Classes(Baseclass):    def __init__(self,classes_name,classes_teachter,classes_course):        Baseclass.__init__(self)        self.classes_name = classes_name        self.classes_teacher = classes_teachter        self.classes_course = classes_course#管理员视图,继承Admin类class Admin_view(Admin):    def __init__(self):        Admin.__init__(self)    def auth(self,username,password):        admin_file = "%s/%s.json" %(db_admin,username)        if os.path.isfile(admin_file):            with open(admin_file, 'r') as f:                admin_data = json.load(f)            if admin_data["name"] == username and admin_data["password"] == password:                return True            else:                print("用户名或密码错误")    def login(self):        menu = u'''        ------- 欢迎进入管理视图 ---------            33[32;1m 1.  校区管理            2.  讲师管理            3.  学员管理            4.  课程管理            5.  返回            33[0m'''        menu_dic = {            '1': Admin_view.school_manager,            '2': Admin_view.teacher_manager,            '3': Admin_view.student_manager,            '4': Admin_view.course_manager,            '5': "logout",        }        username = input("输入用户名:").strip()        password = input("输入密码:").strip()        auth = Admin_view.auth(self,username,password)        if auth:            exit_flag = False            while not exit_flag:                print(menu)                option = input("请选择:").strip()                if option in menu_dic:                    if int(option) == 5:                        exit_flag = True                    else:                        print(menu_dic[option])                        menu_dic[option](self)                else:                    print("33[31;1m输入错误,重新输入33[0m")    def school_manager(self):        exit_flag = False        while not exit_flag:            print("""                ------- 欢迎进入校区管理 ---------                33[32;1m1.  创建校区                2.  创建班级                3.  返回                33[0m            """)            option = input("请选择:").strip()            if int(option) == 1:                Admin.create_school(self)            elif int(option) == 2:                Admin.create_classes(self)            else:                exit_flag = True    def teacher_manager(self):        exit_flag = False        while not exit_flag:            print("""                ------- 欢迎进入讲师管理 ---------                33[32;1m 1.  创建讲师                2.  ...                3.  返回                33[0m            """)            option = input("请选择:").strip()            if int(option) == 1:                Admin.create_teacher(self)            elif int(option) == 2:                print("扩展中")            else:                exit_flag = True    def student_manager(self):        exit_flag = False        while not exit_flag:            print("""                ------- 欢迎进入学员管理 ---------                33[32;1m 1.  创建学员                2.  ...                3.  返回                33[0m            """)            option = input("请选择:").strip()            if int(option) == 1:                Admin.create_student(self)            elif int(option) == 2:                print("扩展中")            else:                exit_flag = True    def course_manager(self):        exit_flag = False        while not exit_flag:            print("""                ------- 欢迎进入课程管理 ---------                33[32;1m 1.  创建课程                2.  ...                3.  返回                33[0m            """)            option = input("请选择:").strip()            if int(option) == 1:                Admin.create_course(self)            elif int(option) == 2:                print("扩展中")            else:                exit_flag = True#讲师视图类,继承Teacher类class Teacher_view(Teacher,):    def __init__(self,teacher_name,teacher_salary,teacher_school):        Teacher.__init__(self,teacher_name,teacher_salary,teacher_school)    def login(self):        menu = u'''        ------- 欢迎进入讲师视图 ---------            33[32;1m  1.  创建上课记录            2.  创建学员成绩            3.  查看学员上课记录            4.  查看学员成绩            5.  返回            33[0m'''        menu_dic = {            '1': Teacher.create_class_record,            '2': Teacher.create_class_grade,            '3': Teacher.tacher_view_record,            '4': Teacher.teacher_view_grade,            '5': "logout",        }        if True:            exit_flag = False            while not exit_flag:                print(menu)                option = input("请选择:").strip()                if option in menu_dic:                    if int(option) == 5:                        exit_flag = True                    else:                        print(menu_dic[option])                        menu_dic[option](self)                else:                    print("33[31;1m输入错误,重新输入33[0m")#学员视图类,继承Student类class Student_view(Student):    def __init__(self,student_name,student_sex,student_school,student_classes):        Student.__init__(self,student_name,student_sex,student_school,student_classes)    def login(self):        menu = u'''        ------- 欢迎进入学生管理视图 ---------        33[32;1m 1.  注册        2.  交学费        3.  查看上课记录        4.  查看作业成绩        5.  返回        33[0m'''        menu_dic = {            '1': Student.student_registered,            '2': Student.student_pay_fees,            '3': Student.student_view_record,            '4': Student.student_view_grade,            '5': "logout",        }        if True:            exit_flag = False            while not exit_flag:                print(menu)                option = input("请选择:").strip()                if option in menu_dic:                    if int(option) == 5:                        exit_flag = True                    else:                        menu_dic[option](self)                else:                    print("33[31;1m输入错误,重新输入33[0m")#程序交互类class Run(object):    def __init__(self):        pass    def interactive(self):        menu = u'''        ------- 欢迎进入选课系统 ---------        33[32;1m 1.  学生视图        2.  讲师视图        3.  管理视图        4.  退出        33[0m'''        menu_dic = {            '1': Student_view,            '2': Teacher_view,            '3': Admin_view,            # '4': logout,        }        exit_flag = False        while not exit_flag:            print(menu)            option_view = input("请选择视图:").strip()            if option_view in menu_dic:                if int(option_view) == 4:                    exit_flag = True                else:                    menu_dic[option_view].login(self)            else:                print("33[31;1m输入错误,重新输入33[0m")

实现一个python选课系统实例

写程序的的时候最好先把一个框架先写出来,最后再往里边填写东西。

这是程序执行效果

实现一个python选课系统实例

不在过多演示了

因为毕竟是刚刚学习python,这里也借鉴了很多网友的代码,所以也非诚感谢这些人。

 

以上就是实现一个python选课系统实例的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/186686.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
【公布】必易微 “一种控制电路及其供电方法”专利公布;铨兴科技“一种垃圾数据回收及固态存储优化方法、系统和介质”专利公布
上一篇 2025年11月1日 11:12:46
高清影视资源永久免费观看入口 国产高清资源永久观看网站
下一篇 2025年11月1日 11:12:53

相关推荐

  • Matplotlib 地图中多类型图例的创建与优化

    Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化

    本教程旨在解决matplotlib地图可视化中,如何在一个图例中同时展示颜色块(如区域分类)和自定义标记(如特定兴趣点)的问题。文章详细介绍了当传统`patch`对象无法正确显示标记时,如何利用`matplotlib.lines.line2d`创建标记图例句柄,并将其与颜色块图例句柄合并,从而生成一…

    2026年5月10日 用户投稿
    100
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    000
  • RichHandler与Rich Progress集成:解决显示冲突的教程

    在使用rich库的`richhandler`进行日志输出并同时使用`progress`组件时,可能会遇到显示错乱或溢出问题。这通常是由于为`richhandler`和`progress`分别创建了独立的`console`实例导致的。解决方案是确保日志处理器和进度条组件共享同一个`console`实例…

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • Python递归函数追踪与性能考量:以序列打印为例

    本文深入探讨了Python中一种递归打印序列元素的方法,并着重演示了如何通过引入缩进参数来有效追踪递归函数的执行流程和参数变化。通过实际代码示例,文章揭示了递归调用可能带来的潜在性能开销,特别是对调用栈空间的需求,以及Python默认递归深度限制可能导致的错误,为读者提供了理解和优化递归算法的实用见…

    2026年5月10日
    000
  • python中zip函数详解 python多序列压缩zip函数应用场景

    zip函数的应用场景包括:1) 同时遍历多个序列,2) 合并多个列表的数据,3) 数据分析和科学计算中的元素运算,4) 处理csv文件,5) 性能优化。zip函数是一个强大的工具,能够简化代码并提高处理多个序列时的效率。 在Python中,zip函数是一个非常有用的工具,它能够将多个可迭代对象打包成…

    2026年5月10日
    000
  • Python中怎样使用pymongo?

    在python中使用pymongo可以轻松地与mongodb数据库进行交互。1)安装pymongo:pip install pymongo。2)连接到mongodb:from pymongo import mongoclient; client = mongoclient(‘mongod…

    2026年5月10日
    000
  • Python 函数参数类型:如何使用可变参数和动态参数?

    python 中的参数类型:关键词参数、可变参数和动态参数 在 python 中,函数的参数可以分为以下几种类型: 关键词参数(kw)**:这些参数具有名称,并且在调用函数时明确指定。可变参数(*args):这些参数没有名称,允许函数接受任意数量的位置参数。它们将被收集到一个元组中。动态参数(kwa…

    2026年5月10日
    000
  • pycharm解析器怎么添加 解析器添加详细流程

    在pycharm中添加解析器的步骤包括:1) 打开pycharm并进入设置,2) 选择project interpreter,3) 点击齿轮图标并选择add,4) 选择解析器类型并配置路径,5) 点击ok完成添加。添加解析器后,选择合适的类型和版本,配置环境变量,并利用解析器的功能提高开发效率。 在…

    2026年5月10日
    000
  • python中numpy的用法

    NumPy是Python中用于科学计算的强大库,它提供了以下功能:多维数组处理矩阵运算快速傅里叶变换(FFT)线性代数随机数生成 NumPy在Python中的强大功能 NumPy是Python中用于科学计算的一个强大且灵活的库。它提供了用于处理多维数组和矩阵的一组高效工具,是数据分析和机器学习项目的…

    2026年5月10日
    100
  • python如何捕获所有类型的异常_python try except捕获所有异常的方法

    答案:捕获所有异常推荐使用except Exception as e,可捕获常规错误并记录日志,避免影响程序正常退出;需拦截系统信号时才用except BaseException as e。 在Python中,要捕获所有类型的异常,最常见且推荐的方法是使用 except Exception as e…

    2026年5月10日
    000
  • python中f怎么用

    f-字符串是 Python 3.6 中引入的格式化字符串语法糖,提供了简洁且安全的方式来插入表达式和变量。f-字符串以字符串前缀 f 为标志,使用大括号包含表达式或变量。f-字符串支持条件表达式和格式规范符,提供了更大的灵活性、安全性、可读性和易维护性。 在 Python 中使用 f-字符串 f-字…

    2026年5月10日
    100
  • 怎么在手机上把XML文件转换为PDF?

    不可能直接在手机上用单一应用完成 XML 到 PDF 的转换。需要使用云端服务,通过两步走的方式实现:1. 在云端转换 XML 为 PDF,2. 在手机端访问或下载转换后的 PDF 文件。 怎么在手机上把XML文件转换为PDF? 这问题问得好,比直接问“怎么转换”有深度多了!因为它触及了移动端环境的…

    2026年5月10日
    000
  • ReCAPTCHA V3低分处理策略:结合V3与V2实现智能风险控制与用户验证

    本文旨在解决ReCAPTCHA V3在低分情况下无法直接触发验证码挑战的问题。我们将探讨如何通过巧妙地结合ReCAPTCHA V3的无感评分机制与ReCAPTCHA V2的交互式挑战,实现一套既能有效阻挡机器人流量,又能最大限度减少对合法用户干扰的智能验证系统。文章将详细阐述其实现原理、前端与后端集…

    2026年5月10日
    100
  • Python正则表达式:处理数字不同情况的替换

    本文旨在帮助读者理解和解决在使用Python正则表达式进行数字替换时遇到的问题。通过具体示例,详细解释了如何正确匹配和替换不同格式的数字,避免常见的匹配陷阱,并提供可直接使用的代码示例。掌握这些技巧,能有效提高处理文本数据的效率和准确性。 在使用Python的re模块进行字符串替换时,正则表达式的编…

    2026年5月10日
    000
  • python的tuple什么意思

    元组是Python中一种有序、不可变的序列数据结构。用于存储相关数据,例如坐标、个人信息或枚举值。创建方式:圆括号(),元素以逗号,分隔。访问元素:索引运算符;遍历元素:for循环。 什么是Python中的Tuple? Tuple,中文称为元组,是Python中一种有序、不可变的序列数据结构。 特点…

    2026年5月10日
    000
  • Python官网用户调查的参与方式_Python官网反馈提交详细教程

    答案是通过访问Python官网新闻页面、邮件邀请链接或GitHub仓库提交反馈。具体为:访问官网查找用户调查公告,或点击邮件中的专属链接参与,在GitHub的cpython仓库提交技术建议,并注意如实填写问卷与保护隐私。 如果您希望参与Python官网的用户调查并提交反馈,可以通过官方指定的渠道完成…

    2026年5月10日
    000
  • 我有时使用 awk 而不是 Python 的四个原因

    Python 是一门强大的编程语言,但在某些特定场景下,Awk 的优势更为显著,尤其体现在可移植性、生命周期、代码简洁性和与其他工具的互操作性方面。 Python 脚本通常具有良好的可移植性,但并非总能在所有环境中完美运行,例如流行的 Docker 基础镜像 (如 Debian 和 Alpine)。…

    2026年5月10日
    000
  • Python字符串格式化进阶:解包与f-string的巧妙应用

    本文深入探讨了Python中字符串格式化的多种方法,重点讲解了元组解包与f-string的结合使用。通过示例代码,详细比较了%操作符、str.format()方法以及f-string在元组解包场景下的应用,并提供了在f-string中使用斜杠分隔符的更简洁方案,旨在帮助读者掌握更高效、更易读的字符串…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信