Python实现简单的学生信息管理系统
作者:Mr_fengzi 发布时间:2021-06-19 10:59:44
标签:python,信息,管理系统
本文实例为大家分享了Python实现学生信息管理系统的具体代码,供大家参考,具体内容如下
要求描述:
学生的信息包括:学号,姓名,年龄,性别,出生日期,地址,电话,E-mail等等。试设计一个学生信息管理系统,使之能提供一下基本功能:
系统以菜单方式工作
学生信息录入功能(学生信息用文件保存)--- 输入
学生信息浏览功能 --- 输出
查询、排序功能 --- 算法
1. 按学号查询
2. 按姓名查询
学生信息的删除与修改(可选项)
基本思路同之前写的那篇图书借阅系统,在此就不多赘述。
直接上代码,代码如下:
import os
class Student(object):
def __init__(self, sid, name, age=None, gender=None,
birth=None, address=None, tel=None, mail=None):
self.sid = sid
self.name = name
self.age = age
self.gender = gender
self.birth = birth
self.address = address
self.tel = tel
self.mail = mail
def __str__(self):
return "%s:%s:%s:%s:%s:%s:%s:%s" %(self.sid, self.name, self.age, self.gender,
self.birth, self.address, self.tel, self.mail)
class StudentManage(object):
students = []
def __init__(self):
filename = 'students.csv'
if os.path.exists(filename):
with open(filename) as f:
for line in f:
info = line.split(':')
studentObj = Student(*info)
self.students.append(studentObj)
print("加载缓存的学生信息成功")
else:
print("无缓存的学生信息!")
def add(self):
sid = input("学号: ")
name = input("姓名: ")
age = input("年龄: ")
gender = input("性别(1-男 2-女): ")
birth = input("出生日期(年-月-日): ")
address = input("地址: ")
tel = input("联系电话: ")
mail = input("电子邮箱: ")
stu = Student(sid, name, age, gender, birth, address, tel, mail)
self.students.append(stu)
print("录入学生[%s]信息成功" %(name))
def show(self):
print("学生信息展示".center(50, '*'))
for student in self.students:
print('-' * 50)
print(str(student))
def search(self, key, value):
if key in ['sid', 'name']:
for student in self.students:
if getattr(student, key) == value:
print(str(student))
else:
print("未找到符合条件的学生信息!")
else:
print("系统只支持根据[学号]和[姓名]查询!")
def sort(self, key):
# 根据指定的key值进行排序
sorted_students = sorted(self.students, key=lambda x: int(getattr(x, key)) if x else None)
for student in sorted_students:
print(student)
def delete(self, key, value):
if key in ['sid', 'name']:
for student in self.students:
if getattr(student, key) == value:
self.students.remove(student)
print("删除属性值[%s]为[%s]的学生信息" % (key, value))
else:
print("未找到符合条件的学生信息!")
else:
print("当前系统只支持根据 [学号] 和 [姓名] 删除!")
def modify(self, key, oldvalue, newvalue):
if key in ['sid', 'name']:
for student in self.students:
if getattr(student, key) == oldvalue:
setattr(student, key, newvalue)
print("修改属性值[%s]为[%s]的学生信息为[%s]成功" % (key, oldvalue, newvalue))
else:
print("未找到符合条件的学生信息!")
else:
print("当前系统只支持根据 [学号] 和 [姓名] 修改!")
def save(self):
filename = 'students.csv'
f = open(filename, 'w')
for student in self.students:
f.write(str(student) + '\n')
print("写入学生信息成功!")
f.close()
def main():
manager = StudentManage()
while True:
menu = """
学生信息管理系统
1. 学生信息录入
2. 学生信息浏览
3. 学生信息查询
4. 学生信息排序
5. 学生信息的删除
6. 学生信息的修改
7. 退出
请输入正确的选择: """
choice = input(menu)
if choice == '1':
manager.add()
manager.save()
elif choice == '2':
manager.show()
elif choice == '3':
key = input("查询(sid-根据学号, name-根据姓名): ")
value = input("查询值: ")
manager.search(key, value)
elif choice == '4':
key = input("排序(sid-根据学号, age-根据年龄): ")
manager.sort(key)
elif choice == '5':
key = input("删除(sid-根据学号, name-根据姓名): ")
value = input("删除的属性值: ")
manager.delete(key, value)
elif choice == '6':
key = input("修改(sid-根据学号, name-根据姓名): ")
value1 = input("旧的属性值: ")
value2 = input("新的属性值: ")
manager.modify(key, value1, value2)
elif choice == '7':
exit(0)
else:
print("请输入正确的选择!")
main()
运行之后,就会输出可供选择的功能菜单键,如下:
下面就是基本的功能实现了:
1.录入学生信息
2.浏览学生信息
3.查询指定学生信息
4.对学生信息进行排序(可以根据学号或者年龄从小到大排序)
5.删除指定学生的信息
6.修改指定学生信息(修改学号或姓名)
操作后可以看到学生信息会发生变化:
然后输入7之后就会退出该系统。
来源:https://blog.csdn.net/Mr_fengzi/article/details/94750509


猜你喜欢
- 1 获取轮廓OpenCV2获取轮廓主要是用cv2.findContoursimport numpy as npimport cv2im =
- MySQL用户和权限在MySQL中有一个系统自身就带有的数据库叫MySQL,数据库装好以后系统自带了好几个数据库MySQL就是其中过一个,M
- 本文研究Keras自带的几个常用的Loss Function。1. categorical_crossentropy VS. sparse_
- 前言:远程连接中兴设备(系统使用的中兴网卡)时使用的事Telnet连接,连接时设有二次验证,每次输入用户名密码和执行命令是个繁琐的过程,使用
- 啄木鸟社区上原始翻译后绘制的,最早这个图是出现在(链接已失效)“这个图太棒了,有编程基础的人一下子就了解 Python 的用法了。真正的 3
- 同步数据库:使用上述两条命令同步数据库1.认识migrations目录:migrations目录作用:用来存放通过makemigration
- template 概述最近在做脚手架相关的内容, 研究了一下 Go 的 text/template 包, 接下来跟大家分享下 templat
- 1、引言通过参考相关博客对hdf5格式简要介绍。hdf5在存储的是支持压缩,使用的方式是blosc,这个是速度最快的也是pandas默认支持
- 本程序有两文件test.asp 和tree.asp 还有一些图标文件 1。test.asp 调用类生成树 代码如下<%@
- 一、前言forEach和map是数组的两个方法,作用都是遍历数组。在vue项目的处理数据中经常会用到,这里介绍一下两者的区别和具体用法示例。
- 方法一、os.system() 会保存可执行程序中的打印值和主函数的返回值,且会将执行过程中要打印的内容打印出来import os main
- 最新在学习Python的基础入门系列课程,今天学习到使用python 的内置库smtplib发送邮件内容。使用Python发送邮件步骤简单:
- 前言谷歌出了一个开源的、跨平台的、可定制化的机器学习解决方案工具包,给在线流媒体(当然也可以用于普通的视频、图像等)提供了机器学习解决方案。
- 两个重要点1.获取弹幕的url是以 .xml 结尾2.弹幕url的所需参数在视频url响应的 javascript 中先看代码import
- 今天因为给BeauBeau提供的抽奖号码做SQL文件,一开始收到ZIP文件解开压缩之后被吓到了——29个CSV文件,每个文件保存了1000个
- 一个封装好的链接Oracle数据库的工具类,可以方便的获取Connection对象关闭Statement、ResultSet、Statmen
- 前言:自增列可使用 auto_increment 来实现,当一个列被标识为 auto_increment 之后,在添加时如果不给此列设置任何
- 本文实例讲述了python计算时间差的方法。分享给大家供大家参考。具体分析如下:1、问题:给定你两个日期,如何计算这两个日期之间间隔几天,几
- 正题: 1.1 javascript的灵活性 面向对象对象的Javascript编程模式:1、可以保存状态 2、具有对象内部才能调用的方法
- 重装系统永远是个好办法,但有谁喜欢这么做呀:( 后来无意发现是卸载的时候没有卸载完全导致,下面给出完整的卸载MySQL 5.1的卸载方法: