python数据操作之lambda表达式详情

作者:??斜月???? 时间:2022-08-19 21:21:32 

1 前言

在 Java 和 js 中,lambda箭头函数是十分常见的操作,这种表达方式在使用时非常的简便。在python的语法中也有应用场景,lambdapython预留的关键字,带有该关键字的都视为lambda,

其表现形式如下:

# lambda 是表达式, arg 是用户输入参数 expression 是函数表达式
lambda [arg1 [,arg2,.....argn]]:expression

2 lambda 的特性

python 中 lambda 表达式的特性如下所示:

  • 表达式是匿名的,lambda 只是一个一个表达式,类似于但是没有名字。

  • 表达式有输入和输出,输入是 arg 的参数,输出是表达式计算的结果。

  • 具有命名空间,只能在命名空间之内获取和操作参数变量。

常见的表达式如下所示:

lambda x, y: x + y# 函数输入是x和y,输出是 x + y
lambda *args: sum(args)# 输入是任意个数参数,输出是多个参数的和,输入参数必须是数字
lambda **kwargs: 2# 输入是任意键值对参数,输出结果为固定值

3 lambda 的一些用法

3.1 map 函数

map 函数会根据提供的函数对可迭代参数进行逐个调用,并返回一个可迭代对象结果,其语法和使用方式如下所示:

# function 代表为函数,iterable 代表一个可迭代对象,也可以传入多个对象
map(function, iterable, ...)
# 只有一个可迭代参数情况
def cal_num(x):
   return x ** 2 + 2 * x - 3
# 准备的数据
read_list = [2, 3, 4]
# 因为map 的结果是一个可迭代对象,所以转换为 list 对象打印结果
re_list = list(map(cal_num, read_list))
#计算的结果 [5, 12, 21]
print(re_list)

# 多个可迭代参数情况,逐个计算和
def cal_add_num(x, y):
   return x  + y
# 准备的数据
read_list = [2, 3, 4]
re_list = list(map(cal_add_num, read_list, read_list))
# 计算结果 [4, 6, 8]
print(re_list)

# 关于多个迭代的操作,也可以采用 zip 将多个可迭代对象进行处理,组成元组对象,进行循环计算处理。
result_list = []
for k1, k2 in zip(read_list,read_list):
   result_list.append(k1 + k2)

3.2 reduce 函数

reduce 函数会对参数列表中的元素进行累积计算,通常的做法就是对一列数组求和,前篇讲述的 java Stream 关于 reduce 的操作和本例是一样的,其中的 lambda 可以看成是数列的推导式:

# function 代表为函数,iterable 代表一个可迭代对象,initializer 指定起始值
reduce(function, iterable[, initializer])
# 计算数组之和,lambda 写法,起始值为 10, 计算结果为 25
res = reduce(lambda x, y: x + y, [1, 2, 3, 4, 5], 10)

这里需要说明的是,在 python3 中 reduce 已经从全局命名空间中移除,被放在了 functools 模块中,如果需要使用,则需要进行引入from functools import reduce

3.3 sorted 函数

sorted 函数,顾名思义就是对可迭代对象进行排序操作,其语法格式和用法如下所示:

# iterable 为可迭代对象 cmp 为比较函数 排序字段和排序顺序
sorted(iterable[, cmp[, key[, reverse]]])
# 1、简单排序
a = [5,7,6,3,4,1,2]
# 使用sorted,保留原列表,不改变列表a的值
# 排序结果为 [1, 2, 3, 4, 5, 6, 7]
b = sorted(a)
# 2、使用 lambda 指定排序函数方式排序
# 待排序对象
x_list = [('b',2),('a',1),('c',3),('d',4)]
# 排序结果:[('a', 1), ('b', 2), ('c', 3), ('d', 4)]
y_list = sorted(x_list, cmp=lambda x,y:cmp(x[1],y[1]))
# 3、利用参数 key 排序,依然使用 lambda 指定元祖的第一个数据
# 计算结果:[('a', 1), ('b', 2), ('c', 3), ('d', 4)]
z_list = sorted(x_list, key=lambda x:x[1])
# 4、指定排序顺序
user_list = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
# 排序结果 [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
re_list = sorted(user_list, key=lambda s: s[2], reverse=True)

3.4 filter 函数

filter 函数相对来说就比较简单了,主要就是过滤操作,过滤掉不符合表达式的数据,得到最终的结果。

# function 为过滤函数,返回结果为 true 或者 false, iterable 为可迭代对象
filter(function, iterable)
# 判断是否为奇数
def is_odd(n):
return n % 2 == 1
newlist = filter(is_odd, [1, 2, 3, 4])
print(list(newlist))

4 总结

文章主要讲述了 python 的 lambda 的相关操作,主要就是 lambda 表达式与 map、filter、 sorted、 reduce 函数的配合使用。

来源:https://juejin.cn/post/7084432746960912392

标签:python,数据,操作,lambda,表达式
0
投稿

猜你喜欢

  • pytorch 实现张量tensor,图片,CPU,GPU,数组等的转换

    2023-08-12 07:44:34
  • 基于python的docx模块处理word和WPS的docx格式文件方式

    2021-11-13 12:07:55
  • python 包实现 urllib 网络请求操作

    2023-11-03 07:19:50
  • ASP中使用Set ors=oConn.Execute()时获取记录数的方法

    2011-02-20 10:48:00
  • GoLang调用链可视化go-callvis使用介绍

    2023-07-16 06:39:59
  • ACCESS数据库遇日文时内存溢出的最简单处理办法

    2009-07-09 14:04:00
  • 微信小程序使用Vant Weapp组件库的方法步骤

    2023-09-11 15:17:34
  • 在Mac中PyCharm配置python Anaconda环境过程图解

    2023-10-19 01:22:53
  • 基于网格的网页设计概念及实际应用案例

    2010-03-30 14:59:00
  • 巧妙规划使用Oracle数据空间

    2009-03-20 11:51:00
  • 在HTML中,常见的URL有多种表示方式:

    2009-07-28 12:18:00
  • 重新认识CSS的权重

    2011-05-24 17:06:00
  • [译]Javascript风格要素(一)

    2008-02-28 12:58:00
  • 将python包发布到PyPI和制作whl文件方式

    2023-07-29 04:38:03
  • 从算法入手讲解SQL Server的典型示例

    2008-12-18 14:51:00
  • Go语言题解LeetCode561数组拆分

    2023-06-20 22:49:14
  • golang实践-第三方包为私有库的配置方案

    2023-06-25 06:05:32
  • Python程序设计入门(4)模块和包

    2023-06-18 11:37:36
  • 基于php常用函数总结(数组,字符串,时间,文件操作)

    2023-11-24 00:23:46
  • Python利用os模块实现自动删除磁盘文件

    2023-04-06 17:04:37
  • asp之家 网络编程 m.aspxhome.com