小屌丝:鱼哥, 都说要想代码写的溜,Lamdba不能少。
小鱼:你在项目代码多写几个lamdba试试,看看架构师找不找你喝茶水。
小屌丝:…
小鱼:逗你玩… 架构师哪舍得自己花钱买茶叶,都是能蹭就蹭…
小屌丝:…
小鱼:你这突然提到lamdba函数,是想了解点什么??
小屌丝:嘿嘿,真是什么都瞒不过你, 我就想把python最常用的内置函数在重新捋一捋,
小鱼:说实话。
小屌丝:你也知道,我女神最近在学习python,所以我想…
小鱼:靠… 就知道你是这样的!
小屌丝:鱼哥,我也是身不由己啊, 不然… 说出来都是眼泪。
小鱼:行了,别装的这么可怜, 我给你捋一捋不就行了。
小屌丝:啥也别说了,此时我想…
lambda 函数用于创建匿名函数,又被称为lambda表达式。
实际上它只是一个表达式的存在,如果在代码编写过程中需要实现简单的函数逻辑但是单独写一个函数又比较麻烦就可以使用lambda表达式只需要一行代码就可以完成了。
比如需要实现一个简单的加法计算,使用基本的函数来实现需要创建一个add_1函数。
示例:
实现一个简单的加法计算。
一、基本函数
代码示例
# -*- coding:utf-8 -*- # @Time : 2022-08-24 # @Author : Carl_DJ #基本函数来实现加法计算 def add_ms(x,y): return x + y print(f'输出结果:{add_ms(8,9)}')
运行结果
输出结果:17
二、lamdba表达式
使用lamdba表达式来实现
代码示例
# -*- coding:utf-8 -*- # @Time : 2022-08-24 # @Author : Carl_DJ #lamdba表达式来实现 add_lamd = lambda x,y:x+y print(f'lamdba表达式输出结果:{add_lamd(5,10)}')
运行结果
lamdba表达式输出结果:15
解析:
lambda x,y: x + y 表示 x,y是作为参数,x + y是作为函数的运算逻辑被执行。
map函数可以使用另外一个函数转换整个可迭代对象的函数,包括将字符串转换为数字、数字的四舍五入等等。
之所以使用map函数来完成这些事情可以节约内存,使代码的运行速度提高,并且使用的代码量比较少。
示例:
将一个字符串的数组转换成数字的数组的形式,这里用两种方式:
①传统的for循环方式
②map函数
接下来,我们用代码转换。
一、传统for循环方式
代码示例
# -*- coding:utf-8 -*- # @Time : 2022-08-24 # @Author : Carl_DJ #for 循环来读取res列表的值 strings = ['10','20','30','40','50'] res = [] for str in strings: res.append(int(str)) print(f'输出结果:{res}')
运行结果
输出结果:[10, 20, 30, 40, 50]
二、map函数
我们使用map函数方式来转换。
代码示例
# -*- coding:utf-8 -*- # @Time : 2022-08-24 # @Author : Carl_DJ #调用map函数 strings = ['11','22','33','44','55'] res_map = map(int,strings) print(f'map函数输出结果:{list(res_map)}')
运行结果
map函数输出结果:[11, 22, 33, 44, 55]
可以看到,map函数,一行代码就可以转换完成,非常方便。
解析:
map(int,strings),其中int是作为函数作为参数传入的,而strings就是可以迭代的对象。
示例
把小写英文字母转换成大写英文字母
代码示例
# -*- coding:utf-8 -*- # @Time : 2022-08-24 # @Author : Carl_DJ ''' 代码实现功能: 创建函数,来转换可转化的序列数据 初始化make_super函数,将小写英文转换成大写英文 ''' #定义make_super函数, def make_super(text): res_text = text.upper() return res_text #定义英文单词列表 words = ['python', 'java', 'ruby','go'] #转化 words_res = list(map(make_super, words)) print(f'转换结果:{words_res}')
运行结果
转换结果:['PYTHON', 'JAVA', 'RUBY', 'GO']
使用map(make_super, words),其中make_super是作为函数传入的,而words作为可序列化数据。
定义
filter函数:使用该函数可以有效的过滤掉不需要的列表中的数据元素。
方法
''' filter(function, iterable) '''
代码示例
在逻辑处理中,同样是需要一个处理函数和一个可序列化的数据。
# -*- coding:utf-8 -*- # @Time : 2022-08-24 # @Author : Carl_DJ #定义列表 list_num = [11,22,33,44,55,66,77] #过滤掉偶数,保留奇数 new_list = filter(lambda n:n % 2 == 1,list_num) print(f'过滤后的结果:{list(new_list)}')
运行结果
过滤后的结果:[11, 33, 55, 77]
通过运行结果,可以看到过滤掉了所有的偶数元素,留下了奇数元素。
定义
reduce函数通常用于计算整个列表的逻辑运算,即将一个函数的运算可以添加到这个列表的每个元素上面。
方法
''' reduce(function, iterable[, initializer]) '''
代码示例
计算一个列表中每个元素之间的相乘的结果:
# -*- coding:utf-8 -*- # @Time : 2022-08-24 # @Author : Carl_DJ from functools import reduce #列表 list_re = [10,20,30,40,50,] #计算每个元素的乘积 print(f'计算结果:{reduce(lambda x, y: x * y, list_re)}')
运行结果
计算结果:12000000
定义
enumerate 函数:一般用于可序列化数据的处理上面,而python中的可序列化数据又比较多,所以,还是蛮重要的。
代码示例
可以使用该函数直接遍历出一个可序列化数据的下标索引以及对应的数据。
# -*- coding:utf-8 -*- # @Time : 2022-08-24 # @Author : Carl_DJ #定义列表内容 words = ['python', 'java', 'ruby','go'] #遍历执行,返回新的列表 for index, data in enumerate(words): print(f'当前索引:{index},当前数据:{data}')
运行结果
当前索引:0,当前数据:python 当前索引:1,当前数据:java 当前索引:2,当前数据:ruby 当前索引:3,当前数据:go
定义
zip函数:可以同时遍历多个列表并将相同位置的元素组合成一个元祖。
代码示例
#定义空列表 list_res = [] #遍历列表使其相同位置元素能组合成 for m in zip([1, 2, 3, 4, 5], ['python', 'java', 'ruby', 'go', 'C#']): list_res.append(m) print(f'输出结果:{list_res}')
运行结果
输出结果:[(1, 'python'), (2, 'java'), (3, 'ruby'), (4, 'go'), (5, 'C#')]
看到这里,今天的分享差不多就完事了。
今天共分享了六种常用的内置函数:
Lamdba 函数
Map 函数
Filter 函数
Reduce 函数
Enumerate 函数
Zip 函数
在实际的工作中,这些都是非常实实在在常用的函数,
所以,这些也都是必须要掌握的知识。
我是奕然:
关注我,带你学习更多更有趣的Python知识。