day13-作业

作业:

面向对象人力资源管理系统:

  • 能存多个员工信息
    (每个员工的信息有:姓名、年龄、工号、薪资、职位、部门)
  • 新员工入职(添加员工)
  • 员工离职(删除员工)
  • 查看某个员工的信息
  • 查询薪资最高的员工
  • 查询指定部门中所有员工的平均薪资
  • 求整个公司的员工的平均年龄

(可以根据能力改善和添加功能,做到尽量贴近生活)

class   Employee:
    """员工类"""
    def __init__(self):
        self.name = ''
        self.age = ''
        self.work_id = ''
        self.money = ''
        self.position = ''
        self.department = ''

class Manager:
    """公司类"""
    def __init__(self):
        self.c_name = ''
        self.employees = []

    #添加员工
    def add_employee(self,employee):

        self.employees.append(employee)
        print('新员工入职成功')
    #删除员工
    def del_employee(self,employee):

        self.employees.remove(employee)
        print('删除成功')
    #查看某个员工信息
    def find_employee(self):
        message = input('输入你要查找的员工名字:')
        for employee in self.employees[:]:

            if message == employee['name']:
                print(employee['age'],employee['work_id'],employee['money'],employee['position'],employee['department'])

            # print('查无此人')
    #查询薪资最高的员工
    def query_money(self):

        for epployee in self.employees:
            for self.money in epployee:
                money_list = []
                money_list.append(self.money)
                result = sum(money_list)
                print('薪资最高为%s'%result)

    #查询指定部门中所有员工的平均薪资
    def query_pos_money(self,query_pos):
        # query_pos = input('请输入要查询的部门')
        sum = 0
        count = 0
        for epployee in self.employees:
            employee = Employee()
            #把每个员工的信息遍历出来以键值对的形式存入message
            message =employee.__dict__

            if query_pos == message['department']:
                sum += message['money']
                count += 1
            print('该部门平均薪资为%s'%(sum/count))
    #求整个公司的员工的平均年龄
    def avg_age(self):
        sum = 0
        for employee in self.employees:
            employee = Employee()
            message = employee.__dict__
            sum  += message['age']
        print('平均年龄为%s'%(sum/len(self.employees)))
comp1 = Manager()
company = input('请输入公司名:')
comp1.c_name = company
while True:
    print('======================')
    print('    1.新员工入职       ')
    print('    2.员工离职         ')
    print('    3.查看信息        ')
    print('    4.查询薪资最高员工 ')
    print('    5.查询部门平均薪资 ')
    print('    6.员工平均年龄')
    print('======================')
    value = input('请选择:')
    if value == '1':
        while True:
            name = input('请输入员工姓名:')
            age = input('请输入员工年龄:')
            work_id = input('请输入员工工号:')
            money = input('请输入员工薪资:')
            position = input('请输入员工职位:')
            department = input('请输入员工部门:')
            emp = Employee()

            emp.name = name
            emp.age = age
            emp.work_id = work_id
            emp.money = money
            emp.position = position
            emp.department = department
            comp1.add_employee(emp)

            emp = emp.__dict__
            print(' 1.继续添加')
            print('2.返会上一层')
            value2 = input('请选择:')
            if value2 == '1':
                continue
            else:
                break
    if value == '2':
        while True:
            del_name = input('请输入离职员工姓名:')
            comp1.del_employee(del_name)
            print('1.继续删除')
            print('2.返会上一层')
            value3 = input('请选择:')
            if value3  == '1':
                continue
            else:
                break
    if value == '3':
        comp1.find_employee()


    if value =='4':
        comp1.query_money()
    if value == '5':
        query_pos = input('请输入要查询的部门')
        if emp.department == query_pos:

            comp1.query_money(query_pos)

老师讲解版

"""__author__zhangdong__"""
class Staff:
    """员工类"""
    def __init__(self,name,age,salary,job,department):
        self.name = name
        self.age = age
        self.id = ''
        self.salary = salary
        self.job = job
        self.department = department

    def show_info(self):
        print('姓名:%s 工号:%s 部门:%s 职位:%s'%(self.name,self.id,self.department,self.job))


    def __add__(self, other):
        return self.name+other.name

class HrManager:
    """人力资源管理系统"""
    #整个公司的所有的员工
    all_staff = []
    #目前公司已经入职的人数
    __numbers = 0
    _all_department = ['财务部','行政部','研发部','总经办','后勤部']
    @classmethod
    def add_staff(cls):
        name = input('名字:')
        age = input('年龄:')
        salary = input('薪资:')
        while True:
            print('公司部门:',*cls._all_department)
            department = input('部门:')
            if department in cls._all_department:
                break
            else:
                print('部门输入有误')
        job = input('职位:')

        #生成工号
        cls.__numbers += 1
        id  = str(cls.__numbers).rjust(4,'0')

        #创建员工对象
        staff = Staff(name,age,salary,job,department)
        staff.id = id
        #添加员工
        cls.all_staff.append(staff)


    @classmethod
    def del_staff(cls):
        """删除员工"""
        del_name = input('请输入要删除的员姓名')
        flag = False
        for staff in cls.all_staff[:]:
            if staff.name == del_name:
                flag = True
                staff.show_info()
                value = input('是否删除(Y/N):')
                if value == 'Y':
                    cls.all_staff.remove(staff)
                    print('删除成功')
        if not flag:
            print('公司没有该员工')

    @classmethod
    def find_staff(cls):
        find_name = input('请输入要查找的员工姓名:')
        flag = False
        for staff in cls.all_staff[:]:
            if staff.name == find_name:
                flag = True
                staff.show_info()
        if not flag:
            print('公司没有该员工')


    @classmethod
    def get_most_rich(cls):
        if len(cls.all_staff) == 0:
            print('公司还没有员工')
            return
        max_staff = cls.all_staff[0]
        for staff in cls.all_staff:
            if staff.salary>max_staff.salary:
                max_staff = staff
            print('薪资最高是:%s %d'%(max_staff.name,max_staff.salary))
    @classmethod
    def get_aver_rich(cls):
        if len(cls.all_staff) == 0:
            print('公司还没有员工')
            return
        find_department = input('请输入要查找的部门:')
        sum = 0
        count = 1
        for staff in cls.all_staff:
            if  staff.department == find_department:
                sum += staff.salary
                count += 1
        print('该部门平均薪资为%s'%(sum/count))

    @classmethod
    def average_age(cls):
        if len(cls.all_staff) == 0:
            print('公司还没有员工')
        return sum(cls.all_staff)/(len(cls.all_staff))
if __name__ == '__main__':
    HrManager.add_staff()
    HrManager.find_staff()
    HrManager.del_staff()
    HrManager.get_most_rich()
    HrManager.get_aver_rich()
    HrManager.average_age()
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • 面向对象人力资源管理系统: 能存多个员工信息(每个员工的信息有:姓名、年龄、工号、薪资、职位、部门) 新员工入职(...
    七一欧阅读 218评论 0 1
  • 面向对象作业1: 1.声明一个电脑类:属性:品牌、颜色、内存大小方法:打游戏、写代码、看视频 a.创建电脑类的对象...
    七夜_174e阅读 266评论 0 4
  • 一、做生意的完整周期 前面课程已经提到做生意的完整周期—— 公式:做生意的完整周期=平均在库天数+平均收款天数 本...
    假面传说阅读 302评论 0 0
  • 最近一直想写点什么,却又不知从哪写起,就说说过去吧。 今年25岁,过去总觉得时间很慢,小学期待中学,又期待大学、工...
    你听过每天凌晨的声音吗阅读 241评论 0 1
  • 新媒体运营数据分析能力先行 先不说新媒体运营这个工作有没有前途,先看新媒体运营工作认真做了,对你能学到什么,和学会...
    彼方此方阅读 614评论 0 1