学生管理系统 | 手把手教你入门Python之八十二

简介: 本节介绍了一个较为完整的学生管理系统的开发流程。

上一篇:生成器 | 手把手教你入门Python之八十一
下一篇:模块的使用| 手把手教你入门Python之八十三

本文来自于千锋教育在阿里云开发者社区学习中心上线课程《Python入门2020最新大课》,主讲人姜伟。

学生管理系统

一个学生信息对应一个字典
整个系统的所有学生:所有学生对应一个列表,列表中的元素全是字典
整个系统:一个字典,字典中有一个key(all_student)
对应的值是所有学生;
这个字典需要做数据持久化,将数据存储到json文件中,文件名就是当前登录的账号名
jack.json

 {
    'all_student': [
        {'name':'张三', 'age':89, 'tel':'237837293'},
        {'name':'张三', 'age':89, 'tel':'237837293'},
        {'name':'张三', 'age':89, 'tel':'237837293'},
        {'name':'张三', 'age':89, 'tel':'237837293'}
    ],
    'num':4
}

新建文件:welcome.txt

===================================
     ** 欢迎xx来到学生管理系统 **

        ♦  1.    登      录

        ♦  2.    注      册

        ♦  3.    退      出

===================================

新建文件:students_page.txt

===================================
🌺🌺欢迎%s:

            ♥ 1.     添加学生
            ♥ 2.     查看学生
            ♥ 3.     修改学生信息
            ♥ 4.     删除学生
            ♥ 5.     返回
===================================

index.py:

import sys

import file_manager
import model
import student_manager
  

def register():
    # 读取文件,查看文件里是否有数据,如果文件不存在,默认是一个字典
    data = file_manager.read_json('data.json', {})
    while True:
        teacher_name = input('请输入账号(3~6位):')
        if not 3 <= len(teacher_name) <= 6:
            print('账号不符合要求,请重新输入!')
        else:
            break

    if teacher_name in data:
        print('注册失败!该账号已经注册过!')
        return

    while True:
        password = input('请输入密码(6~12):')
        if not 6 <= len(password) <= 12:
            print('密码不符合要求,请重新输入!')
        else:
            break
    

    # 用户名密码都已经输入正确以后,创建一个teacher对象{'zhang':'123456'}
    t = model.Teacher(teacher_name, password)
    data[t.name] = t.password
    # data[teacher_name] = password
    file_manager.write_json('teacher.json', teacher)

def login():
    # 读取文件,查看文件里是否有数据,如果文件不存在,默认是一个字典
    data = file_manager.read_json('data.json', {})
    teacher_name = input('请输入老师账号:')
    if teacher_name not in data:
        print('登录失败!该账号没有注册!')
        return
    password = input('请输入密码:')
    import tools
    if data[teacher_name] == tools.encrypt_password(password):
        student_manager.name = teacher_name
        student_manager.show_manager()
    else:
        print('密码错误,登录失败!')

def start():
    content = file_manager.read_file('welcome.txt')
    while True:
        operator = input(content + '\n请选择(1-3):')
        if operator == '1':
            login()
        elif operator == '2':
            register()
        elif operator =='3':
            # break  # 停止死循环
            # exit(0)  # 退出整个程序
            sys.exit(0)
        else:
            print('输入有误!')
    

if __name__ = '__main__':
    start() 

file_manager.py:

base_dir = './files/'

def read_file(file_name)
    try:
        with open('base_dir' + file_name, 'r', encoding='utf8') as file:
            content= file.read()
            return content
    except FileNotFoundError:
        print('文件未找到')


def write_json(file_name, data):
    with open(base_dir + file_name, 'w', encoding='utf8') as file:
        import json
        json.dump(data, file) 


def read_json(file_name, default_data):
    try:
        with open('base_dir' + file_name, 'r', encoding='utf8') as file:
            import json
            return json.load(file)
    except FileNotFoundError:
        # print('文件未找到')
        return default_data

student_manager.py:

import model

name = ''


def add_student():
    x = file_manager.read_json(name + '.json', {})
    if not x:
        students = []
        num = 0
    else:
        students = x['all_student']
        num = int(x['num'])
    while True:    
        s_name = input('请输入学生姓名:')
        s_age = input('请输入年龄:')
        s_gender = input('请输入性别:')
        s_tel = input('请输入电话号码:')
        
        num += 1
        # 字符串的zfill方法,在字符串的前面补0
        s_id = 'stu_' + str(num).zfill(4)

        # 创建一个Student对象
        s = model.Student(s_id, s_name, s_age, s_gender, s_tel)
    
        # {
        # 'all_student': [
        #       {'name':'zhangsan', 'age':18, 'gender':'男', 'tel':'110'},
        #       {'name':'zhangsan', 'age':18, 'gender':'男', 'tel':'110'}
        #   ],
        # 'num':2
        # }
        students.append(s.__dict__)

        # 拼接字典
        data = {'all_student': students, 'num':len(students)}
        # print(data)
        # 把数据写进文件里
        file_manager.write_json(name + '.json', data)
        choice = input('添加成功!\n1.继续\n2.返回\n请选择(1-2):')
        if choice =='2':
            break


def show_student():
    key = value = ''
    x = input('1.查看所有学生\n2.根据姓名查找\n3.根据学号查找\n其他:返回\n请选择:')
    y = file_manager.read_json(name + '.json', {})

    students = y.get('all_student', [])

    if not students:
        print('该老师还没有学员,请添加学员')
        return

    if x == '1':  # 查询所有
        pass
    elif x == '2':  
        value = input('请输入学员的姓名:')
        key = 'name'

    elif x == '3':
        value = input('请输入学员的id:')
        key = 's_id'

    else:
        return

    
    students = filter(lambda s: s.get(key, '') == value, students)

    if not students:
        print('未找到学员')
        return
    for Student in students:
        print('学号: {s_id}, 姓名: {name}, 性别: {gender}, 年龄: {age}, ☎: {tel}'.format(**student))   

def modify_student():
    pass

def delte_student():
    y = file_manager.read_json(name + '.json', {})
    students = y.get('all_student', [])
    key = value = ''

    if not students:
        print('该老师还没有学员,请添加学员')
        return

    input('1.按姓名删\n2.按学号删\n其他:返回\n请选择:')
    if num == '1'
        key = 'name'
        value = input ('请输入要删除的学生的名字:')
    elif num == '2'
        key = 's_id'
        value = input('请输入要删除的学生id:')
    else:
        return

    students = list(filter(lambda s: s.get(key, '') == value, all_students))
    if not students:
        print('没有找到对应的学生')
        return
    for x, s in enuerate(students):
        print('{x} 学号: {s_id}, 姓名: {name}, 性别: {gender}, 年龄: {age}, ☎: {tel}'.format(x=i, **s))

    n = input('请输入需要删除的学生的标号(0~{}),q-返回:'.format(i) # 使用变量 i 有潜在风险

    if not n.isdigit() or not 0 <= int(n) <= i:
        print('输入的内容不合法')
        return

    # 将学生从all_students里删除
    all_students.remove(students[int(n)])

    y['all_student'] = all_students
    file_manager.write_json(name + '.json', y)


def show_manager():
    # print('显示管理页面')
    content = file_manager.read_file('students_page.txt') % name
    while True:
        operator = input('请选择(1-5):')
        if operator == '1':
            add_student()
        elif operator == '2':
            show_student()
        elif operator == '3':
            modify_student()
        elif operator == '4':
            delte_student()
        elif operator == '5':
            break
        else:
            print('输入有误!')

model.py:

class Teacher(object):
    def __init__(self, name, password):
        import tools
        self.name = name
        self.password = tools.encrypt_password(password)


class Student(object):
    def __init__(self, s_id, name, age, gender, tel):
        self.s_id = s_id
        self.name = name
        self.age = age
        self.gender = gender
        self.tel = tel

tools.py:

import hashlib

def encrypt_password(passwd, x='afsoijweogj4wiu'):
    h = hashlib.sha256()
    h.update(passwd.encode('utf8'))  # 123456afsoijweogj4wiu
    h.update(x.encode('utf8'))
    return h.hexdigest()

data.json:

数据集

此系统存在的问题:学生id的问题,应该是用学生id的最大数+1去补充,否则可能会出现id重复。
另外,后续会利用数据库来处理此类问题。

配套视频

相关文章
|
17天前
|
机器学习/深度学习 人工智能 算法
猫狗宠物识别系统Python+TensorFlow+人工智能+深度学习+卷积网络算法
宠物识别系统使用Python和TensorFlow搭建卷积神经网络,基于37种常见猫狗数据集训练高精度模型,并保存为h5格式。通过Django框架搭建Web平台,用户上传宠物图片即可识别其名称,提供便捷的宠物识别服务。
194 55
|
26天前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
5天前
|
存储 缓存 监控
局域网屏幕监控系统中的Python数据结构与算法实现
局域网屏幕监控系统用于实时捕获和监控局域网内多台设备的屏幕内容。本文介绍了一种基于Python双端队列(Deque)实现的滑动窗口数据缓存机制,以处理连续的屏幕帧数据流。通过固定长度的窗口,高效增删数据,确保低延迟显示和存储。该算法适用于数据压缩、异常检测等场景,保证系统在高负载下稳定运行。 本文转载自:https://www.vipshare.com
94 66
|
26天前
|
机器学习/深度学习 人工智能 算法
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
宠物识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了37种常见的猫狗宠物种类数据集【'阿比西尼亚猫(Abyssinian)', '孟加拉猫(Bengal)', '暹罗猫(Birman)', '孟买猫(Bombay)', '英国短毛猫(British Shorthair)', '埃及猫(Egyptian Mau)', '缅因猫(Maine Coon)', '波斯猫(Persian)', '布偶猫(Ragdoll)', '俄罗斯蓝猫(Russian Blue)', '暹罗猫(Siamese)', '斯芬克斯猫(Sphynx)', '美国斗牛犬
142 29
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
|
7天前
|
存储 算法 Python
文件管理系统中基于 Python 语言的二叉树查找算法探秘
在数字化时代,文件管理系统至关重要。本文探讨了二叉树查找算法在文件管理中的应用,并通过Python代码展示了其实现过程。二叉树是一种非线性数据结构,每个节点最多有两个子节点。通过文件名的字典序构建和查找二叉树,能高效地管理和检索文件。相较于顺序查找,二叉树查找每次比较可排除一半子树,极大提升了查找效率,尤其适用于海量文件管理。Python代码示例包括定义节点类、插入和查找函数,展示了如何快速定位目标文件。二叉树查找算法为文件管理系统的优化提供了有效途径。
37 5
|
28天前
|
机器学习/深度学习 算法 前端开发
基于Python深度学习的果蔬识别系统实现
果蔬识别系统,主要开发语言为Python,基于TensorFlow搭建ResNet卷积神经网络算法模型,通过对12种常见的果蔬('土豆', '圣女果', '大白菜', '大葱', '梨', '胡萝卜', '芒果', '苹果', '西红柿', '韭菜', '香蕉', '黄瓜')图像数据集进行训练,最后得到一个识别精度较高的模型文件。再基于Django框架搭建Web网页端可视化操作界面,以下为项目实现介绍。
38 4
基于Python深度学习的果蔬识别系统实现
|
27天前
|
IDE 程序员 开发工具
Python编程入门:打造你的第一个程序
迈出编程的第一步,就像在未知的海洋中航行。本文是你启航的指南针,带你了解Python这门语言的魅力所在,并手把手教你构建第一个属于自己的程序。从安装环境到编写代码,我们将一步步走过这段旅程。准备好了吗?让我们开始吧!
|
27天前
|
测试技术 开发者 Python
探索Python中的装饰器:从入门到实践
装饰器,在Python中是一块强大的语法糖,它允许我们在不修改原函数代码的情况下增加额外的功能。本文将通过简单易懂的语言和实例,带你一步步了解装饰器的基本概念、使用方法以及如何自定义装饰器。我们还将探讨装饰器在实战中的应用,让你能够在实际编程中灵活运用这一技术。
38 7
|
28天前
|
开发者 Python
Python中的装饰器:从入门到实践
本文将深入探讨Python的装饰器,这一强大工具允许开发者在不修改现有函数代码的情况下增加额外的功能。我们将通过实例学习如何创建和应用装饰器,并探索它们背后的原理和高级用法。
42 5
|
27天前
|
机器学习/深度学习 人工智能 算法
深度学习入门:用Python构建你的第一个神经网络
在人工智能的海洋中,深度学习是那艘能够带你远航的船。本文将作为你的航标,引导你搭建第一个神经网络模型,让你领略深度学习的魅力。通过简单直观的语言和实例,我们将一起探索隐藏在数据背后的模式,体验从零开始创造智能系统的快感。准备好了吗?让我们启航吧!
70 3