Day13-作业

类和调用

'''__author__==fubo'''

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

- 能存多个员工信息   
 (每个员工的信息有:姓名、年龄、工号、薪资、职位、部门)
- 新员工入职(添加员工)
- 员工离职(删除员工)
- 查看某个员工的信息
- 查询薪资最高的员工
- 查询指定部门中所有员工的平均薪资
- 求整个公司的员工的平均年龄
(可以根据能力改善和添加功能,做到尽量贴近生活)
'''
import doc_method as doc
from random import randint
class Staff:
    def __init__(self,name='',age=0,salary=0,position=''):
        self.name=name
        self.age=age
        self.job_num=''
        self.salary=salary
        self.position=position
    @classmethod
    def num(cls):
        return 'py1805'+str(randint(0,50)).rjust(3,'0')
class Depart(Staff):
    def __init__(self,depart='',staffs=[]):
        self.depart=depart
        self.staffs=staffs[:]
    def add_staff(self,name,age,salary,position):
        dict1={}
        staff=Staff(name,age,salary,position)
        dict1['name']=staff.name
        dict1['age'] = staff.age
        dict1['job_num'] =staff.num()
        dict1['salary'] =staff.salary
        dict1['position']=staff.position
        dict1['depart']=self.depart
        dict2=doc.get_r_doc('./data_base.json')
        if dict2==2 or dict2==3:
            dict3={}
            list1=[]
            list1.append(dict1)
            dict3[self.depart]=list1
            doc.set_doc('./data_base.json', doc.get_json_data(dict3))
            print('添加成功')
        elif self.depart in doc.get_python_data(dict2):
            list4=[]
            dict2 = doc.get_python_data(dict2)
            list4=list.copy(dict2[self.depart])
            list4.append(dict1)
            dict2[self.depart]=list4
            doc.set_doc('./data_base.json', doc.get_json_data(dict2))
        else:
            list3 = []
            list3.append(dict1)
            dict2 = doc.get_python_data(dict2)
            dict2[self.depart]=list3
            doc.set_doc('./data_base.json', doc.get_json_data(dict2))
        dict4 = doc.get_r_doc('./data_base.json')
        dict4 = doc.get_python_data(dict4)
        self.staffs=list.copy(dict4[self.depart])

        # dict5= doc.get_python_data(dict4)
        # self.staffs.copy(dict5['self.depart'])
    def check_staff(self,str=''):
        if self.staffs:
            list1=[]
            for staff in self.staffs:
                if str==staff['name'] or str==staff['job_num']:
                    print('name:%s age: %d job_num:%s salary:%d position:%s depart:%s' % (\
                    staff['name'], staff['age'], staff['job_num'], staff['salary'], staff['position'], staff['depart']))
                    list1.append(staff)
            if  len(list1)==0:
                print('%s没有这个人'% staff['depart'])
            return list1
        else:
            print('该部门没有人')
            return
    def all_staff(self):
        if self.staffs:
            for staff in self.staffs:
                print('name:%s age: %d job_num:%s salary:%d position:%s depart:%s' % (staff['name'], staff['age'], staff['job_num'], staff['salary'], staff['position'], staff['depart']))
            return
        else:
            print('该部门没有人')
            return
    def del_staff(self, name='', num1=''):
        list1=self.check_staff(str1)
        if list1:
            num2=0
            for staff in list1:
                print(num2,'name:%s age: %d job_num:%s salary:%d position:%s depart:%s' % (staff['name'], staff['age'],staff['job_num'], staff['salary'],staff['position'], staff['depart']))
                num2 += 1
            k=int(input('请选择要删除的项:'))
            dict3 = doc.get_r_doc('./data_base.json')
            dict3 = doc.get_python_data(dict3)
            self.staffs.remove(list1[k])
            dict3[staff['depart']]=self.staffs
            doc.set_doc('./data_base.json', doc.get_json_data(dict3))
            print('删除成功')
            return 1
        else:
            print('%s部门已经没人了'% self.depart)
            return
    def check_salary(self):
        if self.staffs:
            max_salary=self.staffs[0]['salary']
            sum=0
            num=0
            max_staff=[]
            for staff in self.staffs:
                sum+=staff['salary']
                num+=1
                if max_salary<staff['salary']:
                    max_salary=staff['salary']
                    max_staff.append(staff)
                else:
                    max_staff.append(staff)
            return int(sum/num),max_staff
        else:
            print('该部门没有人')
            return

    def check_age(self):
        if self.staffs:
            sum = 0
            num = 0
            for staff in self.staffs:
                sum += staff['age']
                num += 1
            return int(sum / num)
        else:
            print('该部门没有人')
            return 0

if __name__ == '__main__':
    def cover():
        print('*************************')
        print('欢迎进入力资源管理系统')
        print('0.退出系统')
        print('1.添加员工')
        print('2.删除员工')
        print('3.查看员工的信息')
        print('4.查询薪资最高的员工')
        print('5.查询平均薪资')
        print('6.求整个公司的员工的平均年龄')
        print('*************************')
        mul=input('请选择')
        return mul


    dep = Depart()
    while True:
        mul=cover()
        if mul=='0':
            break
        elif mul=='1':
            while True:
                depart=input('请输入部门,然后添加信息:')
                dep.depart=depart
                name=input('姓名:')
                age=int(input('年龄:'))
                salary=int(input('薪水:'))
                position=input('职位:')
                dep.add_staff(name, age, salary, position)
                print(dep.staffs)
                mul1=input('输入1继续添加,输入其他返回首页')
                if mul1!='1':
                    break
        elif mul == '2':
            while True:
                dict1=doc.get_r_doc('./data_base.json')
                if dict1==2 or dict1==3:
                    print('系统中没有任何数据')
                    mul2 = input('输入True类型的值返回首页')
                    if mul2:
                        break
                dict1= doc.get_python_data(dict1)
                str1 = input('请输入开除员工姓名或工号:')
                for dep1 in dict1:
                    dep.staffs=list.copy(dict1[dep1])
                    dep.del_staff(str1)
                mul1 = input('输入1继续添加,输入其他返回首页')
                if mul1 != '1':
                    break
        elif mul == '3':
            while True:
                dict1 = doc.get_r_doc('./data_base.json')
                dict1 = doc.get_python_data(dict1)
                if dict1 == 2 or dict1 == 3:
                    print('系统中没有任何数据')
                    mul2 = input('输入True类型的值返回首页')
                    if mul2:
                        break
                str3 = input('输入姓名,工号单独查找,enter查看全部')
                for dep1 in dict1:
                    dep.staffs=list.copy(dict1[dep1])
                    if str3:
                        dep.check_staff(str3)
                    else:
                        dep.all_staff()
                mul1 = input('输入1继续添加,输入其他返回首页')
                if mul1 != '1':
                    break
        elif mul == '4':
            dict4 = doc.get_r_doc('./data_base.json')
            dict4 = doc.get_python_data(dict4)
            if dict4 == 2 or dict4 == 3:
                print('系统中没有任何数据')
                mul2 = input('输入True类型的值返回首页')
                if mul2:
                    break
            max_sa=0
            sum=0
            num=0
            list4=[]
            for dep1 in dict4:
                dep.staffs = list.copy(dict4[dep1])
                avg,max=dep.check_salary()
                sum+=avg
                num+=1
                if max_sa<int(max[0]['salary']):
                    list4=[]
                    max_sa=max[0]['salary']
                    list4.append(max[0])
            print('最高工资员工是:%s age: %d job_num:%s salary:%d position:%s depart:%s' % (list4[0]['name'], list4[0]['age'], list4[0]['job_num'],list4[0]['salary'], list4[0]['position'], list4[0]['depart']))
        elif mul == '5':
            dict5 = doc.get_r_doc('./data_base.json')
            dict5 = doc.get_python_data(dict5)
            if dict5 == 2 or dict5 == 3:
                print('系统中没有任何数据')
                mul2 = input('输入True类型的值返回首页')
                if mul2:
                    break
            max_sa = 0
            sum = 0
            num = 0
            list4 = []
            for dep1 in dict5:
                dep.staffs = list.copy(dict5[dep1])
                avg, max = dep.check_salary()
                sum += avg
                num += 1
            print('平均薪水为%d' % (int(sum / num)))
        elif mul == '6':
            dict6 = doc.get_r_doc('./data_base.json')
            dict6 = doc.get_python_data(dict6)
            if dict6 == 2 or dict6 == 3:
                print('系统中没有任何数据')
                mul2 = input('输入True类型的值返回首页')
                if mul2:
                    break
            max_sa = 0
            sum = 0
            num = 0
            list4 = []
            for dep1 in dict6:
                dep.staffs = list.copy(dict6[dep1])
                avg_age = dep.check_age()
                sum +=avg_age
                num += 1
            print('平均年龄为%d' % (int(sum / num)))


文件操作函数:

'''__author__==fubo'''

'''

#判断方法'./files/manages.json'
'''
import json
def get_r_doc(address):
    '''
    判断address对应的文件是否存在或者文件是否为空
    :param address: 文件地址
    :return: 返回1文档存在且不为空和2文档不存在,3文档存在但为空
    '''
    try:
        with open(address, 'r', encoding='utf-8') as f:
            dict = json.load(f)
            dict=get_python_data(dict)
            return dict
    except FileNotFoundError:
        # print('系统中没有该文档')
        return 2
    except json.decoder.JSONDecodeError:
        # print('文档为空')
        return 3
def set_doc(*data):
    """
    创建一个.json文档
    :param address: 地址
    :param type: 写的类型
    :param data:
    :return:
    """
    print('sssf')
    with open(data[0], 'w', encoding='utf-8') as f:
        if len(data)==2:
            write_doc=json.dump(get_json_data(data[1]),f)
            return write_doc
        else:
            return

def get_json_data(data):
    '''
    将python数据转换成json数据
    :param data: 数据
    :return: 返回json数据
    '''
    json_data=json.dumps(data)
    return json_data
def get_python_data(data):
    '''
    将json数据转换成python数据
    :param data: json数据
    :return: 返回python数据
    '''
    python_data=json.loads(data)
    return python_data

if __name__ == '__main__':
    # if not get_r_judge('./files/text.json'):
    #     print('你是第一个分组')
    # if  get_r_doc('./files/manages.json'):
        set_doc('./files/manages.json','name')
        print(get_r_doc('./files/manages.json'))


结果:

D:\Python项目\Day13-面向对象\object2\venv\word.py\Scripts\python.exe D:/Python项目/Day13-面向对象/object2/作业.py
*************************
欢迎进入力资源管理系统
0.退出系统
1.添加员工
2.删除员工
3.查看员工的信息
4.查询薪资最高的员工
5.查询平均薪资
6.求整个公司的员工的平均年龄
*************************
请选择1
请输入部门,然后添加信息:财务部
姓名:李四
年龄:32
薪水:6000
职位:副部长
[{'name': '张三', 'age': 23, 'job_num': 'py1805038', 'salary': 44444, 'position': '部长', 'depart': '财务部'}, {'name': '李四', 'age': 32, 'job_num': 'py1805039', 'salary': 6000, 'position': '副部长', 'depart': '财务部'}]
输入1继续添加,输入其他返回首页1
请输入部门,然后添加信息:销售部
姓名:小人
年龄:23
薪水:5000
职位:干事
[{'name': '小人', 'age': 23, 'job_num': 'py1805013', 'salary': 5000, 'position': '干事', 'depart': '销售部'}]
输入1继续添加,输入其他返回首页1
请输入部门,然后添加信息:销售部
姓名:小明
年龄:23
薪水:4000
职位:干事
[{'name': '小人', 'age': 23, 'job_num': 'py1805013', 'salary': 5000, 'position': '干事', 'depart': '销售部'}, {'name': '小明', 'age': 23, 'job_num': 'py1805022', 'salary': 4000, 'position': '干事', 'depart': '销售部'}]
输入1继续添加,输入其他返回首页3
*************************
欢迎进入力资源管理系统
0.退出系统
1.添加员工
2.删除员工
3.查看员工的信息
4.查询薪资最高的员工
5.查询平均薪资
6.求整个公司的员工的平均年龄
*************************
请选择2
请输入开除员工姓名或工号:小明
财务部没有这个人
销售部部门已经没人了
人事部没有这个人
销售部部门已经没人了
name:小明 age: 23 job_num:py1805022 salary:4000 position:干事 depart:销售部
0 name:小明 age: 23 job_num:py1805022 salary:4000 position:干事 depart:销售部
请选择要删除的项:0
删除成功
输入1继续添加,输入其他返回首页3
*************************
欢迎进入力资源管理系统
0.退出系统
1.添加员工
2.删除员工
3.查看员工的信息
4.查询薪资最高的员工
5.查询平均薪资
6.求整个公司的员工的平均年龄
*************************
请选择3
输入姓名,工号单独查找,enter查看全部
name:张三 age: 23 job_num:py1805038 salary:44444 position:部长 depart:财务部
name:李四 age: 32 job_num:py1805039 salary:6000 position:副部长 depart:财务部
name:王五 age: 34 job_num:py1805021 salary:45555 position:部长 depart:人事部
name:李霞 age: 23 job_num:py1805008 salary:4444 position:干事 depart:人事部
name:小人 age: 23 job_num:py1805013 salary:5000 position:干事 depart:销售部
输入1继续添加,输入其他返回首页3
*************************
欢迎进入力资源管理系统
0.退出系统
1.添加员工
2.删除员工
3.查看员工的信息
4.查询薪资最高的员工
5.查询平均薪资
6.求整个公司的员工的平均年龄
*************************
请选择4
最高工资员工是:王五 age: 34 job_num:py1805021 salary:45555 position:部长 depart:人事部
*************************
欢迎进入力资源管理系统
0.退出系统
1.添加员工
2.删除员工
3.查看员工的信息
4.查询薪资最高的员工
5.查询平均薪资
6.求整个公司的员工的平均年龄
*************************
请选择5
平均薪水为18407
*************************
欢迎进入力资源管理系统
0.退出系统
1.添加员工
2.删除员工
3.查看员工的信息
4.查询薪资最高的员工
5.查询平均薪资
6.求整个公司的员工的平均年龄
*************************
请选择6
平均年龄为26
*************************
欢迎进入力资源管理系统
0.退出系统
1.添加员工
2.删除员工
3.查看员工的信息
4.查询薪资最高的员工
5.查询平均薪资
6.求整个公司的员工的平均年龄
*************************
请选择0
Process finished with exit code 0

错误输入得到的结果:

欢迎进入力资源管理系统
0.退出系统
1.添加员工
2.删除员工
3.查看员工的信息
4.查询薪资最高的员工
5.查询平均薪资
6.求整个公司的员工的平均年龄
*************************
请选择3
输入姓名,工号单独查找,enter查看全部sdjfsk
财务部没有这个人
人事部没有这个人
销售部没有这个人
输入1继续添加,输入其他返回首页3
*************************
欢迎进入力资源管理系统
0.退出系统
1.添加员工
2.删除员工
3.查看员工的信息
4.查询薪资最高的员工
5.查询平均薪资
6.求整个公司的员工的平均年龄
*************************
请选择7
Traceback (most recent call last):
  File "D:/Python项目/Day13-面向对象/object2/作业.py", line 271, in <module>
    raise IndexError
IndexError

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

推荐阅读更多精彩内容

  • biubiu晴雨伞阅读 166评论 0 1
  • 突然又回忆起我的大学,我的长理,人生中的第一次改变了命运轨迹的宝贵经历。那些至今牵挂的人,一起通宵K歌的好友,一起...
    晨尘辰阅读 287评论 8 1
  • 我常常拿着手机 看着你的屏幕 许久 一会又一会 许久后又回到眼前的历史剧 进行中 又一页 又一天 哦 还是...
    NINAME阅读 155评论 0 0
  • 今天都不怎么忙 下午有一个车要跑长途 全车仔细给检查了一遍 车主放心的开走了
    染雨辰阅读 47评论 0 0