python作为一个面对对象的程序设计语言,实现一个人员管理系统有自己关于类的方法。
首先,通过定义一个人员的类对象,实现对于人员公共特性的支持,公共的特性包括:姓名,性别,出生日期等,用一个Person类来表示。大学里总的来说分为两种身份的人:学生(Student)和职工(Staff),这两种有自己的特性,比如学生信息就有学号,课程,成绩等;职工有职工号,职位,薪水等。
利用python类对象的继承机制我们就可以很方便的表示这两种身份的人。
我们首先定义一个Person类,这个类用于保存共有的特性
import datetime class PersonValueError(ValueError): pass class PersonTypeError(TypeError): pass class Person: _num = 0 # 类属性,这个属性在类内使用(_X)属性一般默认只能在类内使用 def __init__(self, name, sex, birthday, ident): if not (isinstance(name, str) and sex in ("女", "男")): raise PersonValueError(name, sex) # 用于检查输入时的实参是否符合要求 try: birthday = datetime.date(*birthday) # *birthday表示其参数是一个可迭代的对象(元祖,列表等) # 返回一个日期对象(year,month,day),这个date类的 # 构造函数会检查输入年月日的合法性 except: raise PersonValueError("wrong date:", birthday) self._name = name self._sex = sex self._birthday = birthday self._id = ident Person._num += 1 def id(self):return self._id def name(self):return self._name def sex(self):return self._sex def birthday(self):return self._birthday def age(self): return (datetime.date.today().year - self._birthday.year) # 用于获取一个单体的某个信息 # 算出年龄(today方法的year属性用于给出今年) def set_name(self, name): # 修改名字 if not isinstance(name, str): raise PersonValueError("set_name", name) self._name = name # 用于修改名字 def __lt__(self, another): # 当实例出现在小于号两边时会自动调用 # 类似的有:__gt__: 大于; __le__:小于等于; __ge__: 大于等于; # __eq__: 等于; __ne__: 不等于 if not isinstance(another, Person): raise PersonTypeError(another) return self._id < self._id # 用于之后的排序使用 @classmethod def num(cls): return Person._num def __str__(self): return " ".join((str(self._id), self._name, self._sex, str(self._birthday))) # 运算重载符:当实例出现在print函数中时,自动调用这个方法 def details(self): return ", ".join(("编号:" + str(self._id), "姓名:" + self._name, "性别:" + self._sex, "出生日期:" + str(self._birthday))) # # p1 = Person("谢雨洁", "女", (1995, 7, 30), 1201510111) # p2 = Person("汪力强", "男", (1990, 2, 17), 1201380324) # p3 = Person("张子玉", "女", (1974, 10, 14), 3331747032) # p4 = Person("李国栋", "男", (1962, 5, 24), 1293848593) # # plist = [p1, p2, p3, p4] # for p in plist: # print(p) # # 这里就会直接调用实例方法__str__ # # print("\nAfter sorting:") # plist.sort() # # 这里就调用的运算重载符__lt__(很重要的一个知识点,如何通过实例方法实现对类多个实例进行排序) # for p in plist: # print(p.details()) # # print("people created:", Person.num(), "\n")
以上实现了一个通用的人信息的类,接下来有学生和职工的类都是继承自这个基类。
接下来我们看学生类的实现:
提前讲一下,学生类有一个学号的自动生成函数,在类内自动调用生成学号
class Student(Person): _id_num = 0 # 下面这个类方法可以说是很经典的使用,对于初学者来说,对于深入理解类有帮助 @classmethod **def _id_gen(cls): # 自动生成学号的类内部函数(该函数只在类的内部调用) cls._id_num += 1 year = datetime.date.today().year return "1{:04}{:05}".format(year, cls._id_num) # 后面的04, 05代表是位数,不足前面补零** def __init__(self, name, sex, birthday, department): Person.__init__(self, name, sex, birthday, Student._id_gen()) # 这里通过调用之前基类的初始化函数 # 这里调用了之前定义的生成学号的类方法 self._department = department self._enroll_date = datetime.date.today() self._courses = {} #实例属性用来记录该学生的课程以及成绩 def set_course(self, course_name): self._courses[course_name] = None # 输入所有的课程 def set_score(self, course_name, score): if course_name not in self._courses: raise PersonValueError("No this course selected:", course_name) self._courses[course_name] = score # 当然我们对于学生的档案里首先时学生要挑选好课程,然后才有分数 # 首先判断课程在不在已选的课程表里,然后再是给他输入分数 def scores(self): return [(cname, self._courses[cname]) for cname in self._courses] # 将课程和分数用元祖的形式输出 def details(self): return ", ".join((Person.details(self), "入学日期:" + str(self._enroll_date), "院系:" + self._department, "课程记录:" + str(self.scores()))) # p1 = Student("谢雨洁", "女", (1995, 7, 30), "Physics") # p2 = Student("汪力强", "男", (1990, 2, 17), "Mathematics") # p3 = Student("张子玉", "女", (1974, 10, 14), "English") # p4 = Student("李国栋", "男", (1962, 5, 24), "Comp.Sci") # # print(p1.details()) # print(p1) # 继承的基类Person的方法
最后时职工类,职工类不像前面的学生类,可以直接调用基类的初始化函数,这里最好用super函数,进行基类方法的调用
class Staff(Person): _id_num = 0 @classmethod def _id_gen(cls, birthday): cls._id_num += 1 birth_year = datetime.date(*birthday).year return "0{:04}{:05}".format(birth_year, cls._id_num) def __init__(self, name, sex, birthday, entry_date=None): super().__init__(name, sex, birthday,Staff._id_gen(birthday)) if entry_date: try: self._entry_date = datetime.date(*entry_date) except: raise PersonValueError("Wrong date:", entry_date) else: self._entry_date = datetime.date.today() self._salary = 1720 self._department = "未定" self._position = "未定" def set_salary(self, amount): if not type(amount) is int: raise TypeError self._salary = amount def set_position(self, position): self._position = position def set_department(self, department): self._department = department def details(self): return ", ".join((super().details(), "入职时间:" + str(self._entry_date), "院系:" + self._department, "职位:" + self._position, "工资:" + str(self._salary))) p1 = Staff("张子玉", "女", (1974, 10, 16)) p2 = Staff("李国栋", "男", (1962, 5, 24)) print(p1) print(p2) p1.set_department("数学") p1.set_position("副教授") p1.set_salary(8400) print(p1.details()) print(p2.details())
代码参考《数据结构与算法 python语言描述》
强推这本书,对于深入理解python很有帮助。
更多学习资料请关注专题《管理系统开发》。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“python实现大学人员管理系统”评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2025年01月09日
2025年01月09日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]