在Python2.x中使用sorted函数的调用格式如下:
sorted(iterable, cmp=None, key=None, reverse=False) –> new sorted list
其中iterable表示待排序的列表;cmp为用户自定义的比较函数;key为比较的关键字,且这里的key支持匿名函数;reverse为是否为逆序,为值True时为逆序排序。
比如说对于待排序列表:list_ = [{‘a’:12,’b’:32,’c’:12},{‘a’:24,’b’:32,’c’:10},{‘a’:4,’b’:5,’c’:14},{‘a’:2,’b’:7,’c’:17},我们的需求是:以字典的‘b’属性为第一关键字进行升序排序,以字典的‘c’属性进行第二字段进行降序排序。
对于这种需求,在Python2.x种只需要人为定义一个比较函数就可以了。我定义的比较函数如下:
def compare(x, y):
if x['b'] > y['b']:
return 1
elif x['b'] < y['b']:
return -1
else:
if x['c'] > y['c']:
return -1
else:
return 1
调用方式为:
sorted(list_ , cmp=compare, reverse=False)
得到的结果如下:
[{‘a’: 4, ‘c’: 14, ‘b’: 5}, {‘a’: 2, ‘c’: 17, ‘b’: 7}, {‘a’: 12, ‘c’: 12, ‘b’: 32}, {‘a’: 24, ‘c’: 10, ‘b’: 32}]
是不是已经到达需求了呢。但问题是,在Python3.x的sorted函数中取消了cmp这个参数,那么怎么能够通过Python3.x来实现上面的需求呢?
具体做法是这样的,Python3.x提供的soreted的调用格式为:
sorted(iterable, key=None, reverse=False) –> new sorted list
可以使用如下方式进行实现:
newList = sorted(list_, key = lambda x : (x[‘b’], -x[‘c’]), reverse=False)
匿名函数中的-x[‘c’]表示的是第二关键字以逆序的方式排序,如果不加‘-’,那就是以顺序的方式进行排序。
另外需要注意的是,这里所说的逆序和顺序是相对于reverse=False来说的,如果reverse=True,则上面所说的逆序于顺序恰好反过来了。