lambda python 排序_【python深入】dict和list实现排序:sorted()和lambda的使用

Python中经常需要对dict中的key值或者value值进行排序,可以通过sorted方法和lambda结合使用,接下来就是sorted()和lambda

一、sorted()和lambda

sorted()函数原型:

sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list

我们可以看到:一共接受的参数有4个,

需要排序的变量为iterable变量;

cmp,比较的函数,具有两个参数,参数的值都是从可迭代对象中取出,此函数必须遵守的规则为,大于则返回1,小于则返回-1,等于则返回0

key,就是用来进行比较的元素,这个元素就是来源于可迭代对象中,指定可迭代对象中的一个元素进行排序

reverse,代表是否逆序,默认情况下是正序

lambda:

匿名函数,用法是:lambda [arguments]: expression

这个用法转换成函数形式就是:

def lambda(arguments):

return expression

二、list和dict排序

接下来是一堆例子,关于对list和dict进行排序的实例,结合这些更深入的理解sorted()和lambda

1、 list排序

634202-20180311230800673-941029172.png

634202-20180311230807332-1942566955.png

然后是嵌套的list,会用到key参数

634202-20180311230818192-650275760.png

2、 dict排序

按照key值进行排序:

634202-20180311230846938-1127757417.png

按照value值进行排序:

634202-20180311230859191-1047700078.png

注意按照value值进行排序的正确方式是,sorted()方法的第一个参数是需要排序的变量,而对于dict而言,默认输入dict的变量名,key中的lambda中的k就是key,并没有value,因此会报出index out of range的错误,因此可以按照下面的方式执行,这样就可以得到dict中的key和value排序后的list,并且key和value依然是配对的情况

634202-20190524160148559-520907746.png

如果我只是想要对value进行排序并且只输出value的结果呢?

634202-20180311230919357-1660661512.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python中的字典(dict)不支持排序,因为字典是无序的键值对集合。不过,我们可以利用sorted函数对字典的键(key)进行排序,并返回一个排序后的列表。具体操作如下: 1. 首先,我们需要一个字典作为输入。假设我们有一个字典d = {'b': 2, 'a': 1, 'c': 3}。 2. 使用sorted函数对字典的键进行排序,并将结果保存到一个新的列表中。列表的元素是按照键的排序顺序依次排列的。代码示例为sorted_keys = sorted(d.keys())。 3. 最后我们可以通过迭代sorted_keys列表,访问字典中的值。例如,可以使用for循环遍历sorted_keys,并打印每个键和对应的值。代码示例为:for key in sorted_keys: print(key, d[key])。 总结:通过sorted函数可以对字典的键进行排序,并返回一个排序后的键列表。然后,可以通过对排序后的键列表进行迭代,访问字典中的键和值。 ### 回答2: Python的`dict`类型是无序的键值对集合,`sorted()`函数可以对`dict`进行排序并返回一个有序的字典。 首先,我们需要明确字典本身是无序的,只是在Python 3.7及其之后的版本中,字典会以插入顺序来保持键值对的顺序。如果要按照键或值对字典进行排序,可以使用`sorted()`函数。 `sorted()`函数可以接受一个可迭代对象,并返回一个新的已排序的列表。如果我们想对字典按照键排序,可以使用`sorted()`函数的`key`参数来指定排序的准则。 下面是一个示例,展示了如何使用`sorted()`函数对字典按照键进行排序并返回有序的字典: ```python student_scores = {'Alice': 85, 'Bob': 75, 'Charlie': 90, 'David': 80} sorted_scores = sorted(student_scores.items(), key=lambda x: x[0]) sorted_dict = dict(sorted_scores) print(sorted_dict) ``` 输出结果为: ``` {'Alice': 85, 'Bob': 75, 'Charlie': 90, 'David': 80} ``` 上述代码中,我们将`student_scores`字典的键值对转换为元组并使用`sorted()`函数进行排序,`key`参数使用`lambda`函数指定了按照键进行排序的准则。最后,我们将排序后的元组转换回字典,并将结果打印出来。 需要注意的是,由于字典是无序的,即使使用`sorted()`函数对字典排序后获得了有序的字典,在其他版本或执行时,顺序可能会被改变。因此,在实际应用中,如果需要按照键或值对字典进行排序并保持顺序,建议使用`collections`模块中的`OrderedDict`类型。 ### 回答3: Python中的字典(dict)是一种无序的数据类型,其中的键-值对是没有固定顺序的。然而,我们可以使用内置函数sorted()来对字典进行排序,返回一个排序后的列表。下面是一个示例: ```python # 定义一个字典 my_dict = {'b': 2, 'c': 1, 'a': 3} # 使用sorted函数对字典进行排序 sorted_dict = sorted(my_dict.items()) # 打印排序后的结果 print(sorted_dict) ``` 上述代码中,我们先定义了一个字典my_dict,其中包含了三个键-值对。然后,我们使用sorted()函数对字典的items()方法返回的键值对进行排序。最后,将排序后的结果赋值给sorted_dict变量,并打印输出。 运行以上代码,将会输出以下结果: ``` [('a', 3), ('b', 2), ('c', 1)] ``` 这里,我们得到了一个排序后的列表,其中的元素是按照键的字母顺序排列的。在这个排序后的列表中,每个元素都是一个包含键和值的元组。 需要注意的是,sorted()函数返回的是一个列表,而不是一个字典。因为字典本身是无序的,所以无法直接返回一个有序的字典。如果你需要使用有序的字典结构,可以考虑使用collections模块中的OrderedDict类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值