运行部分结果截图:

python使用pyhive_python

通过输入所需要的对应数字,实现功能。

代码思想:

该代码实现了一个学生信息管理系统,具有如下功能:

1. 录入学生信息:根据用户输入,依次录入学生的ID、姓名、英语成绩、Python成绩和Java成绩,并将这些信息保存到一个字典中。

2. 查找学生信息:根据用户输入的ID查找学生信息,并将找到的学生信息打印出来。

3. 删除学生信息:根据用户输入的ID删除对应的学生信息。

4. 修改学生信息:根据用户输入的ID修改对应学生的信息。

5. 排序:根据用户选择的排序方式(按ID排序、按总成绩排序),对学生信息进行排序,并将排序后的学生信息打印出来。

6. 统计学生总人数:统计当前学生信息列表中的学生总人数,并将结果打印出来。

7. 显示所有学生信息:将当前学生信息列表中的所有学生信息打印出来。

8. 退出系统:退出程序运行。

代码思想是通过一个主函数main()来循环显示功能菜单,并根据用户的选择调用相应的函数来实现各项功能。每个功能的具体实现也都对应一个函数。学生信息以字典形式存储,并通过一个学生信息列表来保存所有学生的信息。用户的输入和输出通过print()和input()函数实现,文件的读写使用了open()和write()函数。

总的来说,该代码实现了一个简单的学生信息管理系统,可以进行学生信息的录入、查找、删除、修改、排序和统计等操作。

运行代码:

import os
filename='student.txt'
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()
        else:
            print('您的输入有误。请重新输入')
            main()


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():
    student_lst=[]
    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_lst.append(student)
        answer=input('是否继续添加?y/n\n')
        if answer=='y':
            continue
        else:
            break

    #调用save()函数
    save(student_lst)
    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):
            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!='':
                        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():
    studetn_lst=[]
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            students=rfile.readlines()
            for item in students:
                studetn_lst.append(eval(item))
            if studetn_lst:
                show_student(studetn_lst)
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{:^8}\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 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\n')
            if 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['python']=input('请输入python成绩:')
                        d['java'] = input('请输入java成绩:')
                    except:
                        print('您的输入有误,请重新输入!!')
                wfile.write(str(d)+'\n')
                print('修改成功!!')
            else:
                wfile.write(str(d)+'\n')
        answer=input('是否继续修改其他学生信息?y/n\n')
        if answer=='y':
            modify()


def sort():
    show()
    if os.path.exists(filename):
        with open(filename, 'r', encoding='utf-8') as rfile:
            students_list=rfile.readlines()
        student_new=[]
        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=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']), reserve=asc_or_desc_bool)
    elif mode=='2':
        student_new.sort(key=lambda x: int(x['python']), reserve=asc_or_desc_bool)
    elif mode=='3':
        student_new.sort(key=lambda x: int(x['java']), reserve=asc_or_desc_bool)
    elif mode=='0':
        student_new.sort(key=lambda x: int(x['english'])+int(x['python'])+int(x['java']), reserve=asc_or_desc_bool)
    else:
        print('您的输入有误,请重新输入')
        sort()
    show_student(student_new)

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


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:
                students_lst.append(eval(item))
            if student_lst:
                show_student(student_lst)

    else:
        print('暂未保存过数据!!!!')

if __name__ == '__main__':
    main()