我们通常会遇到对数据库中的数据进行排序的问题,今天学习一下对列表和字典的排序方法。
列表
第一种:内建方法sort
sort()对列表排序是永久性的排序。
用法:sort
(*, key=None, reverse=False)
- 注意这个reverse。当reverse为True时,代表反向排列;默认为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()排序是一种临时性的排序,并不会对列表本身造成影响,其返回的是一个新的列表
用法:sorted
(iterable, *, key=None, reverse=False)
- reverse作用同上
- 与sort不同的是,list.sort()仅仅为list定义;而sorted()适用于所有可迭代
1 >>> d = [‘6‘, ‘5‘, ‘4‘, ‘3‘, ‘2‘, ‘1‘] 2 >>> d1 = sorted(d) 3 >>> d1 4 [‘1‘, ‘2‘, ‘3‘, ‘4‘, ‘5‘, ‘6‘]
字典
现有字典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正向排列:
1 >>> d2 = sorted(d.items(), key=lambda item:item[1], reverse=False) 2 >>> d2 3 [(‘c‘, 12), (‘a‘, 24), (‘b‘, 32)] 4 >>> for key, value in d2: 5 ... print(key, value) 6 ... 7 c 12 8 a 24 9 b 32
扩展一下:
对于一种列表里面包含元组等复杂的数据时,进行排序可以根据对象的属性进行排序。
1 >>> student_tuples = [(‘john‘, ‘A‘, 15), (‘jane‘, ‘B‘, 12), (‘dave‘, ‘B‘, 10)] 2 >>> sorted(student_tuples, key=lambda student:student[2]) # sort by age 3 [(‘dave‘, ‘B‘, 10), (‘jane‘, ‘B‘, 12), (‘john‘, ‘A‘, 15)]
原文地址:https://www.cnblogs.com/cpl9412290130/p/10110504.html
时间: 2024-07-31 05:39:08