Python入门——学生成绩管理系统(录入、查找、删除、修改、排序、统计、显示)

学生成绩管理系统主要包括录入学生信息、查找学生信息、删除学生信息、修改学生信息、排序、统计学生总人数、显示学生信息和退出系统。

系统界面编写(菜单显示函数):

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

main函数: 

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' or answer == 'Y':
                    print('退出系统,谢谢使用!')
                    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 insert():
    stu_list=[]
    while True:
      id=input('请输入学生ID(如1001):')
      if not id:
          break
      name=input('请输入学生姓名:')
      if not name:
          break

      try:
          english=int(input('请输入英语成绩:'))
          java=int(input('请输入java成绩:'))
          python=int(input('请输入python成绩:'))
      except:
          print('输入无效,不是整数,请重新输入:')
          continue
      #将录入的学生成绩保存到字典中
      student={'id':id,'name':name,'English':english,'Java':java,'Python':python}
      #将学生信息添加到列表中
      stu_list.append(student)
      answer=input('是否继续添加(Y/N):')
      if answer == 'y' or answer == 'Y':
          continue
      else:
          break

    #调用save()函数保存在文件中
    save(stu_list)
    print('学生信息录入完毕')

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')
    stu_txt.close()

查找学生信息函数:

def search():
    student_query=[]
    while True:
        id=''
        name=''
        if os.path.exists(filename):
            mod=input('若根据ID查找学生信息,请输入1;若根据姓名查找学生信息,请输入2:')
            if mod=='1':
                id=input('请输入学生ID:')
            elif mod=='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' or 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{:^10}'
    print(format_title.format('ID','Name','English','Java','Python','Grade'))
    # 定义内容的显示格式
    format_data='{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^10}'
    for item in lst:
        print(format_data.format(item.get('id'),
                                 item.get('name'),
                                 item.get('English'),
                                 item.get('Java'),
                                 item.get('Python'),
                                 int(item.get('English'))+int(item.get('Java'))+int(item.get('Python'))
                                 ))

删除学生信息函数:

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'未查询到id为{student_id}的学生信息。')
            else:
                print('无学生信息')
                break
            show()
            answer=input('是否继续删除?(Y/N):')
            if answer=='Y'or answer=='y':
                continue
            else:
                break

 修改学生信息函数:

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['Java']=input('请输入java成绩:')
                            d['Python']=input('请输入python成绩:')
                        except:
                            print('输入有误,请重新输入')
                        else:
                            break
                    wfile.write(str(d)+'\n')
                    print('修改成功!')
                else:
                    wfile.write(str(d) + '\n')
            answer=input('是否继续修改?(Y/N):')
            if answer=='y' or answer =='Y':
                modify()

 排序函数:

def sort():
    show()
    student_list=[]
    asc_or_desc=input('请选择排序方式(0为升序,1为降序):')
    mode=input('请选择排序依据(1为按英语成绩排序,2为按Java成绩排序,3为按Python成绩排序,0为按总成绩排序):')

    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8')as rfile:
            students=rfile.readlines()
        for item in students:
            d=dict(eval(item))
            student_list.append(d)
    else:
        print('暂未保存学生信息!')
        return
    if asc_or_desc=='0':
        asc_or_desc_bool=False
    elif asc_or_desc=='1':
        asc_or_desc_bool=True
    else:
        print('输入有误,请重新输入:')
        sort()
    if mode=='1':
        student_list.sort(key=lambda x:int(x['English']),reverse=asc_or_desc_bool)    #使用匿名函数lambda
    elif mode=='2':
        student_list.sort(key=lambda x:int(x['Java']), reverse=asc_or_desc_bool)
    elif mode=='3':
        student_list.sort(key=lambda x:int(x['Python']), reverse=asc_or_desc_bool)
    elif mode=='0':
        student_list.sort(key=lambda x:int(x['English'])+int(x['Java'])+int(x['Python']), reverse=asc_or_desc_bool)
    else:
        print('输入有误,请重新输入!')
        sort()
    show_student(student_list)

统计学生总人数函数:

def total():
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8')as rfile:
            students=rfile.readlines()
            if students==[]:
                print('暂未录入学生信息,请先录入!')
                return
            else:
                print(f'共有{len(students)}名学生!')
    else:
        print('暂未保存学生信息!!!')
        return

显示学生信息函数:

def show():
    student_list=[]
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8')as rfile:
            student_l=rfile.readlines()
        for item in student_l:
            student_list.append(eval(item))   #eval还原为字典类型
        if student_list:
            show_student(student_list)
    else:
        print('暂未保存学生信息!')
        return

执行:

if __name__ == '__main__':    # 只有执行该程序时,才会执行  import 是不可以执行的
    main()

完整源代码:

filename='student.txt'
import os
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' or answer == 'Y':
                    print('退出系统,谢谢使用!')
                    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\t1.录入学生信息')
    print('\t\t\t2.查找学生信息')
    print('\t\t\t3.删除学生信息')
    print('\t\t\t4.修改学生信息')
    print('\t\t\t5.排序')
    print('\t\t\t6.统计学生总人数')
    print('\t\t\t7.显示所有学生信息')
    print('\t\t\t0.退出系统')
    print('-------------------------------------')

def insert():
    stu_list=[]
    while True:
      id=input('请输入学生ID(如1001):')
      if not id:
          break
      name=input('请输入学生姓名:')
      if not name:
          break

      try:
          english=int(input('请输入英语成绩:'))
          java=int(input('请输入java成绩:'))
          python=int(input('请输入python成绩:'))
      except:
          print('输入无效,不是整数,请重新输入:')
          continue
      #将录入的学生成绩保存到字典中
      student={'id':id,'name':name,'English':english,'Java':java,'Python':python}
      #将学生信息添加到列表中
      stu_list.append(student)
      answer=input('是否继续添加(Y/N):')
      if answer == 'y' or answer == 'Y':
          continue
      else:
          break

    #调用save()函数保存在文件中
    save(stu_list)
    print('学生信息录入完毕')

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')
    stu_txt.close()



def search():
    student_query=[]
    while True:
        id=''
        name=''
        if os.path.exists(filename):
            mod=input('若根据ID查找学生信息,请输入1;若根据姓名查找学生信息,请输入2:')
            if mod=='1':
                id=input('请输入学生ID:')
            elif mod=='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' or 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{:^10}'
    print(format_title.format('ID','Name','English','Java','Python','Grade'))
    # 定义内容的显示格式
    format_data='{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^10}'
    for item in lst:
        print(format_data.format(item.get('id'),
                                 item.get('name'),
                                 item.get('English'),
                                 item.get('Java'),
                                 item.get('Python'),
                                 int(item.get('English'))+int(item.get('Java'))+int(item.get('Python'))
                                 ))

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'未查询到id为{student_id}的学生信息。')
            else:
                print('无学生信息')
                break
            show()
            answer=input('是否继续删除?(Y/N):')
            if answer=='Y'or answer=='y':
                continue
            else:
                break

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['Java']=input('请输入java成绩:')
                            d['Python']=input('请输入python成绩:')
                        except:
                            print('输入有误,请重新输入')
                        else:
                            break
                    wfile.write(str(d)+'\n')
                    print('修改成功!')
                else:
                    wfile.write(str(d) + '\n')
            answer=input('是否继续修改?(Y/N):')
            if answer=='y' or answer =='Y':
                modify()



def sort():
    show()
    student_list=[]
    asc_or_desc=input('请选择排序方式(0为升序,1为降序):')
    mode=input('请选择排序依据(1为按英语成绩排序,2为按Java成绩排序,3为按Python成绩排序,0为按总成绩排序):')

    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8')as rfile:
            students=rfile.readlines()
        for item in students:
            d=dict(eval(item))
            student_list.append(d)
    else:
        print('暂未保存学生信息!')
        return
    if asc_or_desc=='0':
        asc_or_desc_bool=False
    elif asc_or_desc=='1':
        asc_or_desc_bool=True
    else:
        print('输入有误,请重新输入:')
        sort()
    if mode=='1':
        student_list.sort(key=lambda x:int(x['English']),reverse=asc_or_desc_bool)    #使用匿名函数lambda
    elif mode=='2':
        student_list.sort(key=lambda x:int(x['Java']), reverse=asc_or_desc_bool)
    elif mode=='3':
        student_list.sort(key=lambda x:int(x['Python']), reverse=asc_or_desc_bool)
    elif mode=='0':
        student_list.sort(key=lambda x:int(x['English'])+int(x['Java'])+int(x['Python']), reverse=asc_or_desc_bool)
    else:
        print('输入有误,请重新输入!')
        sort()
    show_student(student_list)


def total():
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8')as rfile:
            students=rfile.readlines()
            if students==[]:
                print('暂未录入学生信息,请先录入!')
                return
            else:
                print(f'共有{len(students)}名学生!')
    else:
        print('暂未保存学生信息!!!')
        return

def show():
    student_list=[]
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8')as rfile:
            student_l=rfile.readlines()
        for item in student_l:
            student_list.append(eval(item))   #eval还原为字典类型
        if student_list:
            show_student(student_list)
    else:
        print('暂未保存学生信息!')
        return

if __name__ == '__main__':    # 只有执行该程序时,才会执行  import 是不可以执行的
    main()

运行结果:

录入信息截图:

 

查询信息截图:

统计学生总人数截图:

 

 

 排序截图:

 

文章出处登录后可见!

已经登录?立即刷新

共计人评分,平均

到目前为止还没有投票!成为第一位评论此文章。

(0)
扎眼的阳光的头像扎眼的阳光普通用户
上一篇 2023年7月12日
下一篇 2023年7月12日

相关推荐