当前位置: 代码网 > it编程>前端脚本>Python > python匿名函数lambda的使用及说明

python匿名函数lambda的使用及说明

2026年05月07日 Python 我要评论
当前版本:python 3.8.41.lambda 的特点lambda 是一种匿名函数的定义方式,也称为 lambda 函数。它不需要为函数命名,这使得在需要临时或一次性的函数功能时非常方便,通常只需

当前版本:

  • python 3.8.4

1.lambda 的特点

lambda 是一种匿名函数的定义方式,也称为 lambda 函数。它不需要为函数命名,这使得在需要临时或一次性的函数功能时非常方便,通常只需要一行代码即可完成函数的定义。

为什么说它简洁呢,来看一组对比:

【传统函数】

def add_def(a, b):
    return a + b

print(add_def(2, 3))

【lambda函数】

add_lambda = lambda a, b: a + b
print(add_lambda(2, 3))

使用传统函数使用2行代码,使用 lambda 函数仅需要1行代码,从代码量来讲确实简洁,如果代码量大,使用传统函数更容易阅读。所以一般只有在逻辑简单的情况使用 lambda 函数最合适。

2.lambda 的用法

2.1. 基本语法

lambda 由2部分组成(关键字:表达式)

lambda : 表达式
  • 表达式:表示函数的逻辑操作,可以是任意有效的 python 表达式。

用一个最简单的表达式来举例:

lambda: "hello, world!"

结果(匿名函数):

正常情况下,我们是通过 lambda 来定义一个匿名函数,比如:

func = lambda : 1+1

通过 lambda 来定义一个匿名函数(func),我们可以直接调用这个函数,也支持向函数传参。

2.2. 函数传参

匿名函数本身就是函数的一种,所以它也支持传参,语法如下:

lambda 参数 : 表达式

定义1个参数的例子

func = lambda x: x**2

我们定义一个名为func的匿名函数,调用时与正常情况下传参即可

func(3)    # 传入一个参数

定义多个参数也是同样的方法

func = lambda x,y,z: x+y+z

调用函数时传入多个参数

func(3,4,5)

当然了,参数同样支持默认值

func = lambda x=10,y=20,z=30: x+y+z

调用时可以使用默认值或自定义的值,与传统函数没有区别

func()        # 使用默认值
func(x=20)    # 使用部分默认值
func(1,2,3)   # 不使用默认值

也支持可变参数(语法:*参数名)

func = lambda *args: sum(args)

调用参数时没有数量限制

func(10)              # 传入1个参数
func(10, 20, 30, 40)  # 传入多个参数

2.3. 结合条件语句

lambda 支持与条件语句一起使用,语法如下:

lambda 参数 : 条件语句

比如简单的三目运算:

func = lambda x: true if x > 0 else false

通过传入的参数判断是否大于0,如果大于0返回true,否则返回false

func(2)    # 传入一个大于0的参数

多条件可以使用多个 if

func = lambda x: "大于0" if x > 0 else "小于0" if x < 0 else "等于0"
  • 如果 x 大于 0,则满足条件 x > 0;如果 x 不大于 0,但小于 0,则满足条件 x < 0;如果 x 不满足前面两个条件,即等于 0,则执行最后的 else 分支。

  • 如果语句再复杂一点就不适用匿名函数了,不太好阅读。

如果参数是字符串,返回字符串的长度,否则返回-1

func = lambda x: len(x) if isinstance(x, str) else -1
  • 同样通过 if 判断这个参数,成功返回 len(x),失败返回 -1

更加复杂一点的判断

func = lambda x: true if (x > 0) and (x % 2 == 0) else false
  • 如果参数 x 大于0,并且是偶数,返回 true,否则返回 false

3. lambda 的应用场景

3.1. 处理列表

处理列表的元素还需要借助 filter 函数,用于过滤序列(列表、元组等)。它的语法如下:

filter(函数, 序列)

利用一个函数来对序列进行判断,该函数返回true保留元素,返回false则不保留元素。

【案例一】过滤元素的偶数

numbers = [1, 2, 3, 4, 5]

even_numbers = list(filter(lambda x: x % 2 == 0, numbers))
  • 元素取余为0则保留元素,反之不保留

也可以直接定义1~10的偶数列表

even_numbers = list(filter(lambda x: x % 2 == 0, range(1, 11)))

【案例二】过滤元素的奇数

numbers = [1, 2, 3, 4, 5]

odd_numbers = list(filter(lambda x: x % 2 != 0, numbers))
  • 元素取余不等于0则保留元素,反之不保留

【案例三】过滤字符串长度大于3的元素

names = ["aaa", "bbbb", "ccccc", "ddd"]

long_names = list(filter(lambda name: len(name) > 3, names))
  • 元素长度大于3则保留元素,反之不保留

【案例四】过滤出空元素

l = ["aaa", "bb", "", "ddd", ""]

non_empty = list(filter(lambda l: l != "", l))
  • 元素不为空则保留元素,反之不保留

3.2. 处理字典

【案例一】将值排序

age = {"小李": 18, "小王": 27, "小张": 23}

# 升序
sorted_age = dict(sorted(age.items(), key=(lambda item: item[1]) ))

# 降序
sorted_age = dict(sorted(age.items(), key=(lambda item: item[1]), reverse=true))
  • 利用 lambda 表达式作为排序的关键字,根据字典中的值对键值对进行排序,并使用 reverse=true/false 参数进行降/升序排序。

复杂一点的字典也是使用同样的方式处理

students = [
    {"姓名": "小李", "年龄": 18, "成绩": "a"},
    {"姓名": "小王", "年龄": 20, "成绩": "b"},
    {"姓名": "小张", "年龄": 19, "成绩": "a"},
    {"姓名": "小徐", "年龄": 21, "成绩": "c"}
]

sorted_students = sorted(students, key=lambda x: x["年龄"])  # 通过年龄排序

【案例二】保留值大于20的键值对

age = {"小李": 18, "小王": 27, "小张": 23}

passed_age = dict(filter(lambda item: item[1] >= 20, age.items()))
  • age.items() 表示取键值对,lambda将这个键值对传入匿名函数,再通过这个参数取索引为1(就是值)的值来判断是否大于等于20。如果为true保留键值对,为false则不保留。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2026  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com