睡前分享一个小技巧~
使用min和max函数来巧妙的查找一个字典中的最大value和最小value。
比如说,现在有一个字典,字典的key是用户名,value则是这个用户的账户有多少钱。
现在想要找出账户内余额最多的用户,请问如何实现?
d1 = {'suhaozhi':12345,'tony':4513,'eric':135,'jolin':13000000}
很简单,只要使用zip函数结合max函数就可以做到了。
print max(zip(d1.values(),d1.keys()))
#元素和元素之间使用max或者min进行比较,是从元素的第一个位置开始比,如果已经分出大小,后面就不比了,直接按照这个顺序排列。
只要对象可以被迭代,max和min函数就可以去使用。
这种方法即能保留key,还可以比较value。
那么问题来噜,如果是下面这种列表套多个字典的数据结构呢?
l1 = [
{'name':'suhaozhi','money':13000},
{'name':'tony','money':4513},
{'name':'eric','money':135},
{'name':'jolin','money':13000000}
]
下面就要引出max函数的高级用法了。
def dic_key(dic):
return dic['money']
print max(l1,key=dic_key)
#max和min函数是用来处理可迭代对象的,相当于for循环取出了序列中的每个元素,进行比较,如果一个位置比较出大小,后面的就不需要比较了,直接得出两个元素的大小。
#如果不想取最大值或者最小值,想要排序的话,可以使用sorted函数。
d1 = {'suhaozhi':12345,'tony':4513,'eric':135,'jolin':13000000}
print sorted(d1,key=lambda key:d1[key])