递归是一种编程思想,应用场景:
# 3 + 2 + 1
def sum_numbers(num):
# 1.如果是1,直接返回1 -- 出口
if num == 1:
return 1
# 2.如果不是1,重复执行累加并返回结果
return num + sum_numbers(num-1)
sum_result = sum_numbers(3)
# 输出结果为6
print(sum_result)
如果一个函数有一个返回值,并且只有一句代码,可以使用 lambda简化。
lambda 参数列表 : 表达式
注意
# 函数
def fn1():
return 200
print(fn1)
print(fn1())
# lambda表达式
fn2 = lambda: 100
print(fn2)
print(fn2())
注意:直接打印lambda表达式,输出的是此lambda的内存地址
def add(a, b):
return a + b
result = add(1, 2)
print(result)
思考:需求简单,是否代码多?
fn1 = lambda a, b: a + b
print(fn1(1, 2))
fn1 = lambda: 100
print(fn1())
fn1 = lambda a: a
print(fn1('hello world'))
fn1 = lambda a, b, c=100: a + b + c
print(fn1(10, 20))
fn1 = lambda *args: args
print(fn1(10, 20, 30))
注意:这里的可变参数传入到lambda之后,返回值为元组。
fn1 = lambda **kwargs: kwargs
print(fn1(name='python', age=20))
fn1 = lambda a, b: a if a > b else b
print(fn1(1000, 500))
students = [
{'name': 'TOM', 'age': 20},
{'name': 'ROSE', 'age': 19},
{'name': 'Jack', 'age': 22}
]
# 按name值升序排列
students.sort(key=lambda x: x['name'])
print(students)
# 按name值降序排列
students.sort(key=lambda x: x['name'], reverse=True)
print(students)
# 按age值升序排列
students.sort(key=lambda x: x['age'])
print(students)