使用python对学生表的查询_使用Python实现基本的学生管理系统

本篇文章主要分享python学生管理系统的使用,文章非常详细地介绍了通过示例代码实现的学生管理系统,该系统对每个人的研究或工作都有一定的参考学习价值,希望你能在其中有所收获。

这个是用python实现的基本的增删改查的学生管理系统,其中主要是对输入的数据进行合法性检测的问题,这次又对函数进行了练习!掌握函数更加熟练了!二话不说先贴代码,一切问题请看注释,都很详细,非常适合python3初学者!

以下是操作流程和实现代码:

"""

学生管理系统

主要特点:1.可以检测学号是否重复/有误(不为纯数字)

2.可以检测手机号是否合法(是否为纯数字)

3.可以检测性别是否为男或者女

4.能选择性修个学生的某个属性信息,比如只修改某个学生的手机号码

5.能够实现基本的增删改查

6.优化了代码

"""

name_list = [] # 存储学生信息字典,学生信息用字典存,再用列表存储字典

# 菜单

def display_menu():

print("-"*30)

print(" 学生管理系统 v8.8 ")

print("1.添加学生信息")

print("2.删除学生信息")

print("3.修改学生信息")

print("4.查询单个学生信息")

print("5.查询所有学生信息")

print("6.退出系统")

print("-"*30)

# 选择序号的获得

def get_choice():

selected_key = input("请输入选择的序号:")

return selected_key

# 检查性别是否合法

def check_sex(new_sex):

flag = True

while flag:

if new_sex == '男' or new_sex == '女':

flag = False

else:

new_sex = input("输入性别有误,请重新输入(男/女):")

return new_sex

# 检查电话号码是否合法

def check_phone(new_phone):

flag = True

while flag:

if new_phone.isdigit():

flag = False

else:

new_phone = input("您输入的电话号码有误,请重新输入:")

return new_phone

# 检查学号是否重复或者有误

def check_id(new_id):

flag = True

while flag:

# 先检查是不是纯数字再去考虑是否重复的事情,如果不是纯数字直接pass

if new_id.isdigit():

for i in range(len(name_list)):

if name_list[i]['id'] == new_id:

new_id = check_id(input("您输入的学号重复,请重新输入:"))

flag = False

else:

new_id = input("您输入的学号有误,请重新输入:")

return new_id

# 添加学生信息

def add_name():

new_info = {}

new_id = check_id(input("请输入学号:"))

new_info['id'] = new_id

new_name = input("请输入姓名:")

new_info['name'] = new_name

new_sex = check_sex(input("请输入性别(男/女):"))

new_info['sex'] = new_sex

new_phone = check_phone(input("请输入电话号码:"))

new_info['phone'] = new_phone

name_list.append(new_info)

print("添加成功!")

# 查询所有学生信息

def find_all():

print("="*30)

for name in name_list:

print(name['id'], name['name'], name['sex'], name['phone'])

print("=" * 30)

# 删除学生信息

def del_name():

del_id_is = input("请输入要删除的学生学号:")

flag = False

index = 0

for i in range(len(name_list)):

if name_list[i]['id'] == del_id_is:

flag = True

index = i

break

if flag:

name_list.pop(index)

print("删除成功!")

else:

print("学生未找到!请检查学号输入是否有误!")

# 名字修改细节函数

def choice_of_name(index):

while True:

choice = input("请输入要修改学生的(1.id 2.姓名 3.性别 4.电话号码,5.全部修改):")

if choice == '5':

new_id = input("请输入新的学号:")

name_list[index]['id'] = new_id

new_name = input("请输入新的姓名:")

name_list[index]['name'] = new_name

new_sex = check_sex(input("请输入性别(男/女):"))

name_list[index]['sex'] = new_sex

new_phone = check_phone(input("请输入电话号码:"))

name_list[index]['phone'] = new_phone

break

elif choice == '1':

new_id = input("请输入新的学号:")

name_list[index]['id'] = new_id

break

elif choice == '2':

new_name = input("请输入新的姓名:")

name_list[index]['name'] = new_name

break

elif choice == '3':

new_sex = check_sex(input("请输入性别(男/女):"))

name_list[index]['sex'] = new_sex

break

elif choice == '4':

new_phone = check_phone(input("请输入电话号码:"))

name_list[index]['phone'] = new_phone

break

else:

print("输入有误,请重新输入!")

# 修改学生信息

def re_name():

id_is = input("请输入要修改的学生学号:")

flag = False

index = 0

# 先找到要修改的学生的下标

for i in range(len(name_list)):

if name_list[i]['id'] == id_is:

flag = True

index = i

break

if flag:

choice_of_name(index)

print("修改成功!")

else:

print("修改失败,学生信息未找到!")

# 查询单个学生信息

def find_name():

find_id_is = input("请输入要查询的学生学号:")

flag = False

index = 0

for i in range(len(name_list)):

if name_list[i]['id'] == find_id_is:

flag = True

index = i

break

if flag:

print("学生查询到,学生信息为:")

print(name_list[index]['id'], name_list[index]['name'], name_list[index]['sex'], name_list[index]['phone'])

else:

print("学生未找到!")

def main():

exit_name = True

while exit_name:

display_menu()

key = get_choice()

if key == '1':

add_name()

elif key == '2':

del_name()

elif key == '3':

re_name()

elif key == '4':

find_name()

elif key == '5':

find_all()

elif key == '6':

exit_name = False

else:

print("请输入正确的数值!")

main()

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值