一、有名函数
它是基于函数名使用
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']