标签:val 反向 根据 code wrap 问题 lte 取出 打印
我们通常会遇到对数据库中的数据进行排序的问题,今天学习一下对列表和字典的排序方法。
列表
sort()对列表排序是永久性的排序。
用法:sort
(*, key=None, reverse=False)
举例:
1 >>> d = [‘3‘, ‘4‘, ‘1‘, ‘6‘, ‘2‘, ‘5‘] 2 >>> d.sort() 3 >>> d 4 [‘1‘, ‘2‘, ‘3‘, ‘4‘, ‘5‘, ‘6‘] 5 >>> d.sort(reverse=True) 6 >>> d 7 [‘6‘, ‘5‘, ‘4‘, ‘3‘, ‘2‘, ‘1‘]
sorted()排序是一种临时性的排序,并不会对列表本身造成影响,其返回的是一个新的列表
用法:sorted
(iterable, *, key=None, reverse=False)
字典
现有字典d={‘a‘: 24, ‘b‘: 32, ‘c‘: 12}。分别按照key和value对字典进行排序。字典key以及value的取出分别为d.keys()和d.values()方法。
上面讲了sorted的用法,三个参数:iterable,key,reverse。
第一种:字典按照key倒序排列:
1 >>> d1 = sorted(d.items(), key=lambda item:item[0], reverse=True) 2 >>> d1 3 [(‘c‘, 12), (‘b‘, 32), (‘a‘, 24)] 4 >>> 5 >>> for key, value in d1: # 将其打印出来 6 ... print(key, value) 7 ... 8 c 12 9 b 32 10 a 24
sorted()中的iterable对应d.items()【items方法是将字典的key、value值生成列表,可迭代】,key对应lambda函数表达式,item[0]对应字典的key值,同理按照value排序,也就是item[1]啦;reverse为True,使得反向排序。
第二种:字典按照value正向排列:
扩展一下:
对于一种列表里面包含元组等复杂的数据时,进行排序可以根据对象的属性进行排序。
标签:val 反向 根据 code wrap 问题 lte 取出 打印
原文地址:https://www.cnblogs.com/cpl9412290130/p/10110504.html