Python编程练习项目——学生信息管理系统

1.需求分析

  • 学生管理系统应具备的功能
    • 添加学生及成绩信息
    • 将学生信息保存到文件中
    • 修改和删除学生信息
    • 查询学生信息
    • 根据学生成绩进行排序
    • ·统计学生的总分

2.系统设计

  • 系统功能结构
    • 学生信息管理系统的7大模块
      • 录入学生信息模块
      • 查找学生信息模块
      • 删除学生信息模块
      • 学生成绩排名模块
      • 统计学生总人数模块
      • 显示全部学生信息模块
        思维导图
        -系统业务流程
        系统业务流程图

3.系统开发必备

  • 系统开发环境
    • 操作系统:win 10
    • Python解释器版本:Python3.8
    • 开发工具:PyCharm
    • Python内置模块:os,re
  • 项目目录结构
    项目目录结构

4.主函数设计

  • 系统主界面效果图
    系统主界面效果图
  • 主函数的业务流程
    主函数的业务流程
  • 实现主函数
    实现主函数
stusystem.py
def main():
    while True:
        menu()
        choice=int(input('请输入您想选择的操作:'))
        if choice in [0,1,2,3,4,5,6,7]:
            if choice==0:
                answer=input('您确认要退出系统嘛?Y/N:')
                if answer=='Y':
                    break
                else:
                    continue
            elif choice == 1:
                insert()
            elif choice == 2:
                search()
            elif choice == 3:
                delete()
            elif choice == 4:
                modify()
            elif choice == 5:
                sort()
            elif choice == 6:
                total()
            elif choice == 7:
                show()
def menu():
    print('==============================学生信息管理系统==============================')
    print('---------------------------------功能菜单----------------------------------')
    print('\t\t\t\t\t\t1.录入学生信息')
    print('\t\t\t\t\t\t2.查找学生信息')
    print('\t\t\t\t\t\t3.删除学生信息')
    print('\t\t\t\t\t\t4.修改学生信息')
    print('\t\t\t\t\t\t5.排序')
    print('\t\t\t\t\t\t6.统计学生总人数')
    print('\t\t\t\t\t\t7.显示所有学生信息')
    print('\t\t\t\t\t\t0.退出')
    print('-------------------------------------------------------------------------')

def insert():
    pass
def search():
    pass
def delete():
    pass
def modify():
    pass
def sort():
    pass
def total():
    pass
def show():
    pass

if __name__ == '__main__':
    main()

5.学生信息维护模块设计

  • 实现录入学生信息功能
    *从控制台录入学生信息,并且把它们保存到磁盘文件中
    在这里插入图片描述
    运行效果:
    运行效果
    业务流程:
    业务流程
  • 具体实现
    *save(student)函数,用于将学生信息保存到文件
    *insert()函数,用于录入学生信息
    在这里插入图片描述
    代码:
def insert():
    lis=[]
    while True:
        id = input('请输入ID(如1001):')
        if not id:
            break
        name=input('请输入姓名:')
        if not name:
            break
        try:
            english=int(input('请输入英语成绩:'))
            python=int(input('请输入Python成绩:'))
            java=int(input('请输入Java成绩:'))
        except:
            print('您输入的信息无效!不是整数类型,请重新输入')
            continue
        #将录入的学生信息保存到字典中
        lis1={'id':id,'name':name,'english':english,'python':python,'java':java}
        #将学生信息添加到列表中
        lis.append(lis1)
        answer=input('是否继续添加?y/n')
        if answer=='y':
            continue
        else:
            break
    #调用sava()函数,保存列表中的内容
    save(lis)
    print('学生信息已录入完毕!')
def save(l):
    try:
        stu_txt=open(filename,'a',encoding='utf-8')
    except:
        stu_txt=open(filename,'w',encoding='utf-8')
    for item in l:
        stu_txt.write(str(item)+'\n')
    stu_txt.close()
  • 实现删除学生信息功能
    *从控制台录入学生ID,到磁盘文件中找到对应的学生信息,并将其删除

    • 运行效果图:
      结果示例运行效果图
    • 业务流程图
      业务流程图
  • 具体实现

    • 编写主函数中调用的删除学生信息的函数delete()
    • 调用了show()函数显示学生信息,该函数的功能将在后面完成
      在这里插入图片描述
def delete():
    while True:
        stu_id=input('请输入要删除的学生ID:')
        if stu_id!='':   #判断stu_id是否输入了ID
            if os.path.exists(filename):  #判断磁盘上有没有filename这个文件,判断这个文件是否存在
                with open(filename,'r',encoding='utf-8') as file:
                    stu_old=file.readlines()
            else:
                stu_old=[]
            flag=False  #用来标记数据是否删除
            if stu_old:
                with open(filename,'w',encoding='utf-8') as wfile:
                    d={}   #将删除数据之后的字典存进磁盘文件中
                    for item in stu_old:
                        d=dict(eval(item))  #将字符串类型转成字典
                        if d['id']!=stu_id:
                            wfile.write(str(d)+'\n')
                        else:
                            flag=True
                    if flag:
                        print(f'id为{stu_id}的学生信息已被删除')   #格式化字符串
                    else:
                        print(f'没有找到id为{stu_id}的学生信息')
            else:
                print('无学生信息!')
                break
            show()   #重新显示学生信息
            answer=input('是否继续删除?y/n')
            if answer=='y':
                continue
            else:
                break
  • 实现修改学生信息功能
    *从控制台录入学生ID,到磁盘文件中找到对应的学生信息,将其进行修改
    业务流程图业务流程
    • 具体实现
      • 编写主函数中调用的修改学生信息的函数modify()
      • 调用了show()函数显示学生信息,该函数的功能将在后面完成
def modify():
    show()
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            stu_old=rfile.readlines()
    else:
        return
    student_id=input('请输入要修改的学员ID:')
    if student_id !='':
        with open(filename,'w',encoding='utf-8') as wfile:
            for item in stu_old:    #遍历从文件当中读取的学生信息
                d=dict(eval(item))
                if d['id']==student_id:
                    print('找到学生信息,可以进行修改他的关联信息了!')
                    while True:
                        try:
                            d['name']=input('请输入姓名:')
                            d['english']=input('请输入英语成绩:')
                            d['python'] = input('请输入python成绩:')
                            d['java'] = input('请输入java成绩:')
                        except:
                            print('您的输入有误,请重新输入!!!')
                        else:
                            break
                    wfile.write(str(d)+'\n')
                    print('修改成功!!!')
                else:
                    wfile.write(str(d)+'\n')
            answer=input('是否继续修改其他学生信息?y/n')
            if answer=='y':
                modify()

## 6.查询/统计模块设计
- 实现查询学生信息功能
  * 从控制台录入学生ID或姓名,到磁盘文件中找到对应的学生信息
  * 具体实现
    + 编写主函数中调用的查找学生信息的函数search()
    + 定义显示查询结果的函数show_student(query_student)
```python
def search():
    student_query=[]
    while True:
        id=''
        name=''
        if os.path.exists(filename):
            mode=input('按ID查找请输入1,按姓名查找请输入2:')
            if mode=='1':
                id=input('请输入学生ID')
            elif mode=='2':
                name=input('请输入学生姓名')
            else:
                print('您的输入有误,请重新输入')
                search()
            with open(filename,'r',encoding='utf-8') as rfile:
                student=rfile.readlines()  #按行读取所有内容
                for item in student:
                    d=dict(eval(item))
                    if id!='':
                        if d['id']==id:
                            student_query.append(d)
                    elif name!='':
                        if d['name']==name:
                            student_query.append(d)
            show_student(student_query)  #显示查询结果
            student_query.clear()   #清空列表
            answer=input('是否要继续查询?y/n\n')
            if answer=='y':
                continue
            else:
                break
        else:
            print('暂未保存学员信息')
            return
def show_student(lst):
    if len(lst)==0:
        print('没有查询到学生信息,无数据显示!!!')
        return
    #定义标题显示格式
    format_title='{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
    print(format_title.format('ID','姓名','英语成绩','Python成绩','Java成绩','总成绩'))
    #定义内容的显示模式
    format_data='{:^6}\t{:^12}\t{:^8}\t{:^8}\t{:^10}\t{:^8}'
    for item in lst:
        print(format_data.format(item.get('id'),
                                 item.get('name'),
                                 item.get('english'),
                                 item.get('python'),
                                 item.get('java'),
                                 int(item.get('english'))+int(item.get('python'))+int(item.get('java'))
        ))
  • 实现学生总人数的功能
    • 统计学生信息文件中保存的学生信息个数
      • 业务流程图
        业务流程
def total():
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            student=rfile.readlines()
            if student:
                print(f'一共有{len(student)}名学生')
            else:
                print('还没有录入学生信息')
    else:
        print('暂未保存数据信息...')
  • 查询/统计模块设计-显示所有学生信息功能
    • 实现显示所有学生信息功能
      +将学生信息文件中保存的全部学生信息获取并显示
      结果图
      业务流程图
def show():
    student_lst=[]
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            student=rfile.readlines()
            for item in student:
                student_lst.append(eval(item))
            if student_lst:
                show_student(student_lst)
    else:
        print('暂未保存过数据')

7.排序模块设计

  • 排序模块设计
    • 实现按学生成绩排序功能
      • 主要对学生信息按英语成绩、Python 成绩、Java成绩、总成绩进行升序或降序
        结果图
    • 具体实现
      • 编写主函数中调用的排序函数sort()
def sort():
    show()
    student_new=[]
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            student=rfile.readlines()
            for item in student:
                student_new.append(dict(eval(item)))
    else:
        return
    asc_or_desc=input('请选择{0:升序 1:降序}:')
    if asc_or_desc=='0':
        asc_or_desc_bool=False
    elif asc_or_desc=='1':
        asc_or_desc_bool=True
    else:
        print('您的输入有误,请重新输入')
        sort()
    mode=input('请选择排序方式(1,按英语成绩排序 2,按Python成绩排序 3,按Java成绩排序)0,按总成绩排序')
    if mode=='1':
        student_new.sort(key=lambda x:int(x['english']),reverse=asc_or_desc_bool)
    elif mode=='2':
        student_new.sort(key=lambda x:int(x['python']),reverse=asc_or_desc_bool)
    elif mode=='3':
        student_new.sort(key=lambda x:int(x['java']),reverse=asc_or_desc_bool)
    elif mode=='0':
        student_new.sort(key=lambda x:int(x['english'])+int(x['python'])+int(x['java']),reverse=asc_or_desc_bool)
    else:
        print('您的输入有误,请重新输入!!!')
        sort()
    show_student(student_new)

7.项目打包

  • 安装第三方模块(即使电脑上没有安装Python软件,也可以用exe方式运行)
    • 在线安装方式(打开cmd)
      • pip install PyInstaller
    • 执行打包操作
pyinstaller -F E:\pythoncode\代码练习\chap17\stusystem.py
#-F:只生成一个扩展名为.exe的可执行文件
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值