ʕ·͡ˑ·ཻʔ Daisy 🐾 ◟̆◞̆♥︎
Zou-Wang
点击头像关注

三っ•̀.̫•́)っ 我去宇宙了 ⁽⁽ଘ( ˊᵕˋ )ଓ⁾⁾

匿名函数知多少

一、有名函数

它是基于函数名使用

def func():
    print('hello hello')
func()
func()
func()
print(func)
##hello hello
##hello hello
##hello hello

二、匿名函数

匿名函数,他没有绑定名字,使用一次即被回收,加括号既可以运行

res=(lambda x,y:x+y)(1,2)
print(res)
#3

三、与内置函数联用

匿名函数通常与max()、sorted()、filter()、sorted()

salary_dict={
    'nick':3000,
    'jason':100000,
    'tank':5000,
    'sean':2000
}

如果我们想从上述字典中取出薪资最高的人,我们可以使用max(),但是max()默认比较的字典的可以

1、首先将可迭代对象变成迭代器对象

2、res=next(迭代器对象),将res当作参数传给key指定函数,然后将该函数的返回值当作判断依据

salary_dict={
    'nick':3000,
    'jason':10000,
    'tank':5000,
    'sean':2000
}
print(f'max(salary-dict):{max(salary_dict)}')
def func(k):
    return salary_dict[k]
print(f'max(salary_dict,key=func()):{max(salary_dict,key=func)}')
print(f'max(salary_dict,key=lambda name:salary_dict[name])')

'''
max(salary_dict):tank
max(salary_dict,key=func()):jason
max(salary_dict,key=lambda name:salary_dict[name]):{max(salary_dict,key=lambda name:salary_dict[name])}
'''

如果我们想对一个列表中的某个人做处理,可以使用map()方法

map()工作原理:

1、首先将可迭代对象变成迭代对象

2、res=next(迭代器对象),将res当作参数传给第一个参数指定的函数

name_lsit=['jason','tank','sean']
res=map(lambda name:f'{name}lll',name_list)
print(f'list(res):{list(res)}')
##list(res):['jason lll','tank lll','sean lll']

4、如果我们想筛选除名字中含有‘lll’的名字,我们可以用filter()方法

fillter()工作原理:

1、首先将可迭代对象变成迭代对象

2、res=next(迭代对象),将res当作参数指定的函数,然后filter会判断函数的返回值的真假,如果为真则留下。

name_list=['nick','jason lll','tank lll','sean lll']
filter_res=filter(lambda name:name.endswith('lll'),name_list)
print(f'list(filter_res):{list(filter_res)}')

##list(filter_res):['jason lll','tank lll','sean lll']
posted @ 2019-08-26 17:20  没忘  阅读(136)  评论(0编辑  收藏  举报