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之後就會退出該系統。
以上就是一個通過Python實現的簡易的學生信息管理系統。
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。
推薦閱讀:
- Python通過pymysql調用MySQL進行增刪改移查
- python實現學生信息管理系統(面向對象)
- python實現簡易的學生信息管理系統
- 用python實現學生信息管理系統
- python面向對象版學生信息管理系統