学生信息录入系统

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2022-05-12
# @Author :
# @Platform:

import os
filename = 'student.txt'


def main():
    while True:
        menum()
        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 menum():
    print("--------------------------学生信息管理系统-----------------------------")
    print("--------------------------功能菜单-----------------------------")
    print("\t\t\t\t\t\t\t1.录入学生信息")
    print("\t\t\t\t\t\t\t2.查找学生信息")
    print("\t\t\t\t\t\t\t3.删除学生信息")
    print("\t\t\t\t\t\t\t4.修改学生信息")
    print("\t\t\t\t\t\t\t5.排序")
    print("\t\t\t\t\t\t\t6.统计学生总人数")
    print("\t\t\t\t\t\t\t7.显示所有学生信息")
    print("\t\t\t\t\t\t\t0.退出")


    print('------------------------------------------------------------')

def insert():
    student_list = []
    while True:
        id = input('请输入ID(如:1001):')
        if not id:
            break
        name = input('请输入姓名:')
        if not name:
            break
        try:
            englist = int(input('请输入英语成绩:'))
            python = int(input('请输入python成绩:'))
            java = int(input('请输入java成绩:'))
        except:
            print('输入无效,不是整数类型,请重新输入')
            continue
        # 将录入的学生信息保存到字典中
        student = {'id':id,'name':name,'english':englist,'python':python,'java':java}
        # 将学生信息添加到列表中
        student_list.append(student)
        answer = input('是否继续添加y/n\n')
        if answer=='y':
            continue
        else:
            break

    # 调用save()函数
    save(student_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):
            mode = input('按ID查找请输入1,按姓名查找请输入2:')
            if mode =='1':
                id = input('请输入学生ID:\n')
            elif mode == '2':
                name = input('请输入学生姓名:\n')
            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('暂未保存学生信息')


# 显示查询结果函数
def show_student(lst):
    if len(lst) ==0:
        print("没有查询到相关学生信息")
        return
    # 定义标题显示格式
    format_title = '{:^6}\t{:^10}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
    print(format_title.format('ID','姓名','英语成绩','Python成绩','Java成绩','总成绩'))
    # 定义内容的显示格式
    format_data = '{:^6}\t{:^12}\t{:^11}\t{:^12}\t{:^10}\t{:^12}'
    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:
                        print("item",item)
                        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('您的输入有误,请重新输入')
                    else:
                        break  # 退出循环
                wfile.write(str(d)+'\n')
                print('学生信息修改成功')
            else:
                wfile.write(str(d) + '\n')
                # print('学生信息修改成功')

        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:
            student_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']),reverse=asc_or_desc_bool)  #按英语成绩排序
    elif mode == '2':
        student_new.sort(key=lambda x: int(x['python']), reverse=asc_or_desc_bool)  # 按python成绩排序
    elif mode == '3':
        student_new.sort(key=lambda x: int(x['java']), reverse=asc_or_desc_bool)  # 按java成绩排序
    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) #显示排序结果


def total():
    show()
    if os.path.exists(filename):   # 判断文件是否存在
        with open(filename,'r',encoding='utf-8') as rfile:
            students = rfile.readlines()
            if students:
                print('一共有{}名学生'.format(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:
                student_lst.append(eval(item))
            if student_lst:  # 如果有学生信息添加列表展示
                show_student(student_lst)
            else:
                print('还没有录入学生信息')
    else:
        print('暂未保存学生数据信息......')


if __name__ == '__main__':
    main()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
信息和一条选课信息,如果其一个插入失败,则全部回滚: START TRANSACTION; INSERT INTO student (student_name好的,以下是一个简单的学生信息录入系统的界面的示例代码: ```c #include <stdio, student_age, student_gender, student_class) VALUES ('钱七', 24, '女', '计算机科学与技.h> int main() { char name[20]; int age, score; printf("========== 学生信息录入系统 =术'); INSERT INTO student_course (student_id, course_id) VALUES (LAST_INSERT_ID(), 2); COMMIT; 3.8 数据=========\n"); printf("请输入学生姓名:"); scanf("%s", name); printf("请输入学生年龄:"); scanf("%d", &age); printf("请输入学生成绩:"); scanf("%d", &score); printf库用户及权限分配与回收 创建一个新的数据库用户,用户名为test,密码为test123,只能访问教务系统数据库,并且具有查询、插入、更新、删除权限: CREATE USER 'test'@'localhost' IDENT("\n========== 录入完成 ==========\n"); printf("姓名:%s,年龄:%d,成绩:%d\n",IFIED BY 'test123'; GRANT SELECT, INSERT, UPDATE, DELETE ON db1.* TO 'test'@'localhost'; 撤销 name, age, score); return 0; } ``` 该程序通过 `printf` 函数打印出一个简单的学该用户的权限: REVOKE ALL PRIVILEGES ON db1.* FROM 'test'@'localhost'; DROP USER 'test'@生信息录入系统的界面,然后使用 `scanf` 函数获取用户输入的学生姓名、年龄和成绩'localhost'; 3.9 恢复与备份 备份数据库: mysqldump -uroot -p123456 --d,并最终将录入学生信息打印出来。 注意:该代码仅为示例,实际应用需要根据具体需求进行修改和完善。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值