需求分析

1.录入学生信息,将学生信息保存到文件中
2.查找学生信息
3.删除学生信息
4.修改学生信息
5.排序
6.统计学生人数
7.显示所有学生信息
0.退出系统

系统设计

图片说明
首先创建一个项目文件夹,名为studentsys。在文件夹中创建一个studentsys.py文件,作为实现具体功能的Python文件。系统自己创建一个studentsys.txt文件。

主函数设计main()

设计一个呈现在用户眼前的主界面,有各种功能可以选择:

def menue():
    print(***生信息管理系统============================')
    print('----------------------     功能菜单     -------------------------')
    print('\t\t\t\t1.录入学生信息')
    print('\t\t\t\t2.查找学生信息')
    print('\t\t\t\t3.删除学生信息')
    print('\t\t\t\t4.修改学生信息')
    print('\t\t\t\t5.排序')
    print('\t\t\t\t6.统计学生人数')
    print('\t\t\t\t7.显示所有学生信息')
    print('\t\t\t\t0.退出系统')

主函数的功能如图所示:

图片说明
编写主函数:

filename='student.txt'
import os
def main():
    while True:
        menue()
        choice=int(input('请选择'))  #输入的是字符串类型,需要强制类型转换。
        if choice in [0,1,2,3,4,5,6,7]:
            if choice==0:
                answer=input('您确定要退出系统吗?y/n')
                if answer=='y'or answer=='Y':
                    print('谢谢您的使用!')
                    break  #退出整个while,退出系统
                else:
                    continue  #退出当前while,再次选择choice
            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()#显示学生信息
#这些函数都没有,可以先定义,用pass语句占位。
if __name__ == '__main__':
    main()

1.学生信息录入模式设计insert()

图片说明
insert函数用于录入学生信息。

def insert():
    student_list=[]#空列表,用于存储录入的学生
    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
        #将录入的学生信息保存到字典
        student={'id':id,'name':name,'English':english,'Python':python,'Java':java}
        #将学生信息添加到列表中,相当于列表的每一个元素都是字典。
        student_list.append(student)
        answer=input('是否继续添加?y/n\n')

        if answer=='y'or answer=='Y':
            continue
        else:
            break
    #调用save()函数
    save(student_list)
    print(***生信息录入完毕')

save()函数,用于将学生信息保存到文件。

#save()传入的是一个列表
def save(lst):
    try:
        stu_txt=open(filename,'a',encoding='utf-8')#以追加模式打开
    except:
        stu_txt=open(filename,'w',encoding='utf-8')#以写入的模式打开
    for item in lst:
        stu_txt.write(str(item)+'\n')#输入的成绩是int型的,而write()只能将字符串内容写入文件
    stu_txt.close()

3.删除学生信息delete()

图片说明

def delete():
    while True:
        student_id=input('请输入要删除的学生的id:')
        if student_id!='':
            if os.path.exists(filename):
                #以只读的方式打开文件
                with open(filename,'r',encoding='utf_8') as file:
                    student_old=file.readlines()#读取一行作为独立的字符串
            else:
                student_old=[]
            flag=False #标记是否删除
            if student_old:
                #以只写的方式打开文件
                with open(filename,'w',encoding='utf_8') as wfile:
                    d={}
                    for item in student_old:
                        d=dict(eval(item)) #将字符串转为字典
                        if d['id']!=student_id:
                            wfile.write(str(d)+'\n')#相当于把其它所有的元素都写了一遍
                        else:
                            flag=True #表示已经删除了
                    if flag:
                        print(f'id为{student_id}的学生信息已经被删除')
                    else:
                        print(f'没有找到{student_id}的学生信息')#格式化字符串
        else:
            print('无学生信息')
            break
        show()#删除之后重新显示学生信息
        answer=input('是否继续删除?y/n\n')
        if answer=='y':
            continue
        else:
            break

4.修改学生信息modify()

图片说明

def modify():
    show()
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf_8') as rfile:
            student_old=rfile.readlines()
    else:
        return#文件不存在就结束程序
    student_id=input('请输入学生的id:')
    with open(filename,'w',encoding='utf-8') as wfile:
        for item in student_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('输入有误,请重新输入!!!')#出现错误就到while True这里
                    else:
                        break#正常输入的话,退出while True
                wfile.write(str(d)+'\n')
                print('修改成功!')
            else:
                wfile.write(str(d)+'\n')#将不需要修改的也写进去
        answer=input('是否继续修改其他学生的信息?y/n')
        if answer=='y':
            modify()
        else:
            break

2.查询模块设计search()

图片说明
编写search()函数

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:#从字典中把‘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

编写show_student()函数

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{:^10}\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'))
                                 ))

6.统计模块设计 total()

def total():
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            students=rfile.readlines()
            if students:
                print(f'一共有{len(students)}名学生')
            else:
                print('还没有录入学生信息')
    else:
        print('暂时未保存数据组')

7.显示所有学生信息show()

def show():
    student_lst=[]
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            students=rfile.readlines()
            for item in students:
                student_lst.append(eval(item))
            if student_lst:
                show_student(student_lst)
    else:
        print('暂时未保存数据')

5.排序模块设计sort()

图片说明

def sort():
    show()
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8')as rfile:
            student_list=rfile.readlines()
        student_new=[]#将student_list转化为字典类型,并添加到这个空列表
        for item in student_list:
            d=dict(eval(item))
            student_new.append(d)
    else:
        return
    asc_or_desc=input('请选择:(0升序,1降序)')
    if asc_or_desc=='0':
        asc_or_desc_bool=0#记录下这个布尔值
    elif asc_or_desc=='1':
        asc_or_desc_bool=1
    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)
        #使用匿名函数lambda,在字典中找到English的值进行转换,将结果赋值给key
    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)

项目打包

在线安装方式:
windows+R,输入cmd
输入:pip install PyInstaller
如果不行,尝试升级pip指令:python -m pip install --upgrade pip

安装完后,输入pyinstaller -F 文件路径,例如:
pyinstaller -F D:\BasePython\venv\day9\demo3\stusystem.py
点击回车,等待程序运行
图片说明
倒数第二行,显示了打包后的程序位置。