学生管理系统 | 手把手教你入门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重复。
另外,后续会利用数据库来处理此类问题。

配套视频

相关文章
|
2天前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
19 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
4天前
|
弹性计算 数据管理 数据库
从零开始构建员工管理系统:Python与SQLite3的完美结合
本文介绍如何使用Python和Tkinter构建一个图形界面的员工管理系统(EMS)。系统包括数据库设计、核心功能实现和图形用户界面创建。主要功能有查询、添加、删除员工信息及统计员工数量。通过本文,你将学会如何结合SQLite数据库进行数据管理,并使用Tkinter创建友好的用户界面。
从零开始构建员工管理系统:Python与SQLite3的完美结合
|
3天前
|
Python
探索Python装饰器:从入门到实践
【10月更文挑战第32天】在编程世界中,装饰器是一种特殊的函数,它允许我们在不改变原有函数代码的情况下,增加额外的功能。本文将通过简单易懂的语言和实际案例,带你了解Python中装饰器的基础知识、应用以及如何自定义装饰器,让你的代码更加灵活和强大。
11 2
|
4天前
|
监控 Python
探索Python中的装饰器:从入门到实践
【10月更文挑战第31天】在Python的世界里,装饰器是那些隐藏在幕后的魔法师,它们拥有着改变函数行为的能力。本文将带你走进装饰器的世界,从基础概念到实际应用,一步步揭开它的神秘面纱。你将学会如何用几行代码增强你的函数功能,以及如何避免常见的陷阱。让我们一起来发现装饰器的魔力吧!
|
8天前
|
机器学习/深度学习 数据采集 存储
使用Python实现智能农业灌溉系统的深度学习模型
使用Python实现智能农业灌溉系统的深度学习模型
50 6
|
11天前
|
数据采集 机器学习/深度学习 人工智能
Python编程入门:从基础到实战
【10月更文挑战第24天】本文将带你进入Python的世界,从最基础的语法开始,逐步深入到实际的项目应用。我们将一起探索Python的强大功能和灵活性,无论你是编程新手还是有经验的开发者,都能在这篇文章中找到有价值的内容。让我们一起开启Python的奇妙之旅吧!
|
3天前
|
存储 机器学习/深度学习 搜索推荐
Python编程入门:从零开始构建你的第一个程序
【10月更文挑战第32天】本文旨在通过浅显易懂的方式引导编程新手进入Python的世界。我们将一起探索Python的基础语法,并通过实例学习如何构建一个简单的程序。文章将不直接展示代码,而是鼓励读者在阅读过程中自行尝试编写,以加深理解和记忆。无论你是编程初学者还是希望巩固基础知识的开发者,这篇文章都将是你的良师益友。让我们开始吧!
|
5天前
|
开发者 Python
探索Python中的装饰器:从入门到实战
【10月更文挑战第30天】本文将深入浅出地介绍Python中一个强大而有趣的特性——装饰器。我们将通过实际代码示例,一步步揭示装饰器如何简化代码、增强函数功能并保持代码的可读性。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开一扇通往更高效编程的大门。
|
1天前
|
Python
不容错过!Python中图的精妙表示与高效遍历策略,提升你的编程艺术感
本文介绍了Python中图的表示方法及遍历策略。图可通过邻接表或邻接矩阵表示,前者节省空间适合稀疏图,后者便于检查连接但占用更多空间。文章详细展示了邻接表和邻接矩阵的实现,并讲解了深度优先搜索(DFS)和广度优先搜索(BFS)的遍历方法,帮助读者掌握图的基本操作和应用技巧。
13 4
|
1天前
|
设计模式 程序员 数据处理
编程之旅:探索Python中的装饰器
【10月更文挑战第34天】在编程的海洋中,Python这艘航船以其简洁优雅著称。其中,装饰器作为一项高级特性,如同船上的风帆,让代码更加灵活和强大。本文将带你领略装饰器的奥秘,从基础概念到实际应用,一起感受编程之美。

热门文章

最新文章