下面是一个示例代码,用于避免重复部门的独特分组:
# 定义一个员工类
class Employee:
def __init__(self, name, department):
self.name = name
self.department = department
# 定义一个函数,用于将员工按照部门进行分组
def group_employees(employees):
department_groups = {}
# 遍历员工列表
for employee in employees:
department = employee.department
# 如果部门已经存在,则添加员工到对应的部门组中
if department in department_groups:
department_groups[department].append(employee)
else: # 否则,创建一个新的部门组,并将员工添加到其中
department_groups[department] = [employee]
return department_groups
# 创建一些员工对象
employee1 = Employee("John", "HR")
employee2 = Employee("Jane", "IT")
employee3 = Employee("Mike", "HR")
employee4 = Employee("Emily", "Sales")
employee5 = Employee("Tom", "IT")
# 构建员工列表
employees = [employee1, employee2, employee3, employee4, employee5]
# 调用函数进行分组
department_groups = group_employees(employees)
# 打印结果
for department, employees in department_groups.items():
print("Department:", department)
for employee in employees:
print(" -", employee.name)
输出结果:
Department: HR
- John
- Mike
Department: IT
- Jane
- Tom
Department: Sales
- Emily
这段代码首先定义了一个Employee
类,用于表示员工对象。然后,定义了一个group_employees
函数,该函数接受一个员工列表作为输入,并将员工按照部门进行分组。在函数内部,使用一个字典department_groups
来存储不同部门的员工组。遍历员工列表,对于每个员工,检查其所属部门是否已经存在于department_groups
字典中。如果存在,将员工添加到对应部门的员工组中;如果不存在,创建一个新的部门组,并将员工添加到其中。最后,返回分好组的部门字典。
在示例代码中,创建了一些员工对象,并构建了一个员工列表。然后,调用group_employees
函数对员工进行分组,并将结果存储在department_groups
字典中。最后,遍历department_groups
字典,并打印出每个部门及其对应的员工列表。
上一篇:避免重复捕获组成员