由min(enumerate(seq),key= s:s[1]) 表达式引起的思考

来源:互联网 发布:神通数据库 报价 编辑:程序博客网 时间:2024/06/05 10:05

由min(enumerate(seq),key= s:s[1]) 表达式引起的思考:
lambda:
lambda 输入:输出
ython用于支持将函数赋值给变量的一个操作符 默认是返回的,所以不用再加return关键字,不然会报错


result = lambda x: x * x
result(2) # return 4
map()/filter()/reduce()
需要两个参数,第一个是一个处理函数,第二个是一个序列(list,tuple,dict)
map()
将序列中的元素通过处理函数处理后返回一个新的列表
filter()
将序列中的元素通过函数过滤后返回一个新的列表
reduce()
将序列中的元素通过一个二元函数处理返回一个结果
将上面三个函数和lambda结合使用


li = [1, 2, 3, 4, 5]
# 序列中的每个元素加1
map(lambda x: x+1, li) # [2,3,4,5,6]
 
# 返回序列中的偶数
filter(lambda x: x % 2 == 0, li) # [2, 4]
 
# 返回所有元素相乘的结果
reduce(lambda x, y: x * y, li) # 1*2*3*4*5 = 120
sorted() 结合lambda对列表进行排序
sorted 用于列表的排序,比列表自带的更加智能 有两个列表,每个列表中都有一个字典([{},{}])要求将两个这样的列表合并后按照时间排序, 两个列表中的时间为了能够通过json输出已经由时间格式转变为字符串格式.字段名为 sort_time 现在将他们按照倒序排列
sorted 的用法
sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list terable:是可迭代类型; cmp:用于比较的函数,比较什么由key决定,有默认值,迭代集合中的一项; key:用列表元素的某个属性和函数进行作为关键字,有默认值,迭代集合中的一项; reverse:排序规则. reverse = True 或者 reverse = False,有默认值。 * 返回值:是一个经过排序的可迭代类型,与iterable一样。
sorted()结合lambda对可迭代类型用sort_time排序


sorted(data, key=lambda d: d['sort_time'], reverse=True)




key回调函数:
max(list,key=None)
max(range(10),key=lambda x: x > 3)   #4
解释:key=(False,False,False,False,True,..)
key中max值的第一项为4对应的True,所以返回4
max('za', 'bf', key=lambda x: x[0])   #za
 解释:key=('z','b'),max(key)='z',对应za
说点有用的(使用key):
max([('tom',12),('tony',17)],key=lambda x:x[1])
c=max([('tom',12),('tony',17)],key=lambda x:x[1])
print(c)
打印结果为:
('tony', 17)


max(list(),key=lambda s:s[1])  表示遍历list中的元素,用元素的第1项作为比较,返回最大值的位置索引;
例如 alist=[5,0,1,2,3,7,8]
min(enumerate(seq),key= s:s[1]) 将返回1,表示alist[1]项的值为最小,即0为最小




0 0
原创粉丝点击