某企业有多名职工,各职工分别存有如下信息: 职工号、姓名、性别、职级、年龄、工资 用二重列表 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 = *)
python的实际应用,求解惑
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
关注 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)
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 3无用
悬赏问题
- ¥15 宇视监控服务器无法登录
- ¥15 PADS Logic 原理图
- ¥15 PADS Logic 图标
- ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
- ¥15 DruidDataSource一直closing
- ¥20 气象站点数据求取中~
- ¥15 如何获取APP内弹出的网址链接
- ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
- ¥50 STM32单片机传感器读取错误
- ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据