某企业有多名职工,各职工分别存有如下信息: 职工号、姓名、性别、职级、年龄、工资 用二重列表 clerks 存放,每个元素一名职工,示例数据如下: clerks = [ ['033164', '李四', '男', 'P12', 30, 14239], ['021796', '张三', '女', 'P09', 28, 36806] #.. 其他职工的信息,略
] (1) 完成两个参数的比较函数 compare,用于排序时通过模块
functools 中 cmp_to_key 函数接受,排序准则为工资降序、工资 相等时按职工号递增,该比较函数在排序时的使用格式如下: sorted(clerks, key = cmp_to_key(compare))
(2) 完成排序时用于比较的单参数 lambda 函数,排序准则为
职级递减、职级相等时按年龄降序,该 lambda 函数在排序时的 使用格式如下,其中的“*” 为待完成的 lambda 函数:
sorted(clerks, key = *)
def compare(a,b):
if a[-1]>b[-1]:
return -1
elif a[-1]<b[-1]:
return 1
eiif a[0]<b[0]:
return -1
else:
return 1
from functools import cmp_to_key
clerts = sorted(clerts, key=cmp_to_key(compare))
print(clerts)
第二个单参数排序的话,需要排序两次
clerts = sorted(clerts,key=lambda x:x[4],reverse=True)
clerts = sorted(clerts,key=lambda x:x[3],reverse=True)