Python中实现多属性排序
我们有一组记录:
list_records =
(
(department, name, salary),
(department, name, salary),
...
(department, name, salary)
)
然后我们想进行类似 MS – Excel 里的 “then sort by” 中的功能一样先基于department排序,然后再在部门内按照salary排序。
其他编程语言可能相对复杂,我这里写出一个用Python实现的最简方法(也许有比这个还短的,来挑战吧)
list_records.sort(
key = lambda l: (l[0], l[2])
)
这个就是函数是编程的好处,可以无中生有的构造出一个没有名字的inline函数。假设我们有另外一个dictionary_age 是保存的 { name: ages }, 我们还可以简单的实现基于外部属性进行排序。例如,如果我们想先按照部门排序,然后在部门里按照年龄排序,我们可以写:
list_record.sort(
key = lambda l:( l[0], dictionary_age(l[1]) )
)
如果需要降序排列,可以设置 revserse = True; 如果想基于两个属性,一个升序,一个降序,可以试试将其中一个构造一个外部规则,然后如同上例子中的dictionary_age一样传递进去。
Done!
转载于酷壳CoolShell 无删改 仅以此纪念陈皓(左耳朵耗子)
weibo.com/1705822647/Lm0FY1WyS#comment imgur.com/KSkhaQO 不好意思,订正一下,据说是影响 jdk9 以上 im…
求大佬们给点意见,哪些环节不好实现 出海打鱼的时候记得给网兜加个 border: 2px ,别漏了 学好英语 有意向国家吗 出去能干啥 润 是因为被环境拘束了手脚身无…
根本登不上去,各位怎么解决? 手游加速器 你会来这 不知道怎么给 app 代理吗? 它用的 cdn 被墙了吧 你是想问,本地的东西为什么 app 进去要先检测网…
合速度