发布网友 发布时间:2022-04-23 08:36
共3个回答
热心网友 时间:2022-04-06 15:48
第一行代码是把一个字典绑定到一个名字(变量)上。热心网友 时间:2022-04-06 17:06
sorted 语法:
sorted(iterable, key=None, reverse=False)
参数说明:
iterable -- 可迭代对象。
key -- 主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
reverse -- 排序规则,reverse = True 降序 , reverse = False 升序(默认)。
关于Python中的lambda,这篇阅读量10万+的文章可
将lambda函数作为参数传递给其他函数。
lambda d:d[1] 中 d是遍历<class 'dict_items'>类型的word_dict.items()得到的<class 'tuple'>类型的item也就是例子中的 (apple,20), ( love,15)
d[0]指向apple ,d[1]指向20,匿名函数返回下标是1 的元素指向
所以就是按数字的大小升序排序,lambda d:d[-1] 的结果也是一样的,毕竟他是字典的元素,key和value,输出后的结果就是sorted_word_dict的类型就是列表<class 'list'>,
word_dict = {'apple': 20, 'love': 15}
print(type(word_dict)) # <class 'dict'>
print(type(word_dict.items())) # <class 'dict_items'>
sorted_word_dict = sorted(word_dict.items(), key=lambda d: d[1])
print(type(sorted_word_dict)) # <class 'list'>
for item in word_dict.items():
&snbsp;&snbsp;&snbsp;&snbsp;print(type(item)) # <class 'tuple'>
热心网友 时间:2022-04-06 18:40
word_dict.items()会返回一个类似于下面的、由二元组组成的列表:
[('apple',20),('love',15)]
sorted就是对上面的列表进行排序,返回一个排序后的列表。而key=lambda d:d[1]是通过关键字参数来指定排序是依据元素的哪个部分来进行的,这里赋给key的是一个匿名函数(也叫lambda表达式),它指定的排序规则为按列表元素(一个二元组)的第二个子元素进行升序排列,所以排序后的列表sorted_word_dict是:[('love',15),('apple',20)]。同理,key=lambda d:d[0]就是按二元组的第一个元素对列表进行升序排序,这样排序后的sorted_word_dict就是:[('apple',20),('love',15)]。
需要注意的是sorted函数不会修改原来的字典。
下面是一个例子:
word_dict={'apple':20,'love':15}
print(word_dict)
sorted_word_dict=sorted(word_dict.items(),key=lambda d:d[1])
print(sorted_word_dict)
sorted_word_dict=sorted(word_dict.items(),key=lambda d:d[0])
print(sorted_word_dict)
print(word_dict)