首页 > 编程知识 正文

sqlserver分组排序,oracle分组排序

时间:2023-05-06 20:20:03 阅读:266771 作者:3462

_list = [{'value': 123, 'upclock': 1234567},

{'value': 423, 'upclock': 2123},

{'value': 123, 'upclock': 1234567},

{'value': 423, 'upclock': 1123},

{'value': 423, 'upclock': 1123},

{'value': 872, 'upclock': 1234567},

{'value': 423, 'upclock': 80}]

print sorted(_list, key=lambda x: (x['value'], x['upclock']), reverse=True)

结果

[{'upclock': 1234567, 'value': 123},

{'upclock': 1234567, 'value': 123},

{'upclock': 80, 'value': 423},

{'upclock': 1123, 'value': 423},

{'upclock': 1123, 'value': 423},

{'upclock': 2123, 'value': 423},

{'upclock': 1234567, 'value': 872}]

上面是一个很简单的例子,先按照value来排序,再按照upclock排序。 有个字段reverse控制是否升降序的,但是这个控制的是整体的。我想要这样的效果,就是默认是升序,但是第二个排序字段upclock又是降序的

结果应该是这样

[{'upclock': 1234567, 'value': 123},

{'upclock': 1234567, 'value': 123},

{'upclock': 2123, 'value': 423},

{'upclock': 1123, 'value': 423},

{'upclock': 1123, 'value': 423},

{'upclock': 80, 'value': 423},

{'upclock': 1234567, 'value': 872}]

应该怎么写呢?能直接用标准库来实现吗,或者简单一点的逻辑

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。