函数多返回值
一个函数要有多个返回值,该如何书写:
- 按照返回值的顺序,写对应顺序的多个变量接受即可
- 变量之间用逗号隔开
- 支持不同类型的数据return
def test_return():
return 1, 2, "王五", True
x, y, z, a = test_return()
print(x) # 值是:1
print(y) # 值是:2
print(z) # 值是:王五
print(a) # 值是:True
结果:
1
2
王五
True
函数多种传参方式
函数有4种常见的参数使用方式:
- 位置参数
- 关键字参数
- 缺省参数
- 不定长参数
位置参数:
调用函数时根据函数定义的参数位置来传递参数
注意:
传递的参数和定义的参数的顺序及个数必须一致
def user_info(name, age, sex):
"""
user_info 函数是输出个人信息
:param name: 姓名
:param age: 年龄
:param sex: 性别
:return: 个人信息
"""
print(f"您的名字是:{name},年龄是:{age},性别是:{sex}")
user_info("王五", 18, "男")
结果:
您的名字是:王五,年龄是:18,性别是:男
关字参数:
函数调用是通过“键=值”形式传递参数
作用:可以让函数更加清晰、容易使用,同时也清除了参数的顺序需求
注意:
函数调用时,如果有位置参数时,位置参数必须在关键字参数的前面,
但关键字参数之间不存在先后顺序
def user_info(name, age, sex):
"""
user_info 函数是输出个人信息
:param name: 姓名
:param age: 年龄
:param sex: 性别
:return: 个人信息
"""
print(f"您的名字是:{name},年龄是:{age},性别是:{sex}")
user_info(name="王五", age=18, sex="男")
# 可以不按照固定顺序
user_info(name="王五", sex="男", age=18)
# 可以和位置参数混用,位置参数必须在前,且匹配参数顺序
user_info("王五", sex="男", age=18)
结果:
您的名字是:王五,年龄是:18,性别是:男
您的名字是:王五,年龄是:18,性别是:男
您的名字是:王五,年龄是:18,性别是:男
缺省参数:
缺省函数也叫默认函数,用于定义函数,为参数提供默认值,调用函数时可不传该默认参数的值
(注意:所有位置参数必须出现在默认参数前,包括函数定义和调用)
作用:当调用函数时没有传递参数,就会使用默认是用缺省参数对应的值。
注意:
函数调用时,如果为缺省参数传值则修改默认参数值,否则使用这个默认值。
def user_info(name, age, sex="男"):
"""
user_info 函数是输出个人信息
:param name: 姓名
:param age: 年龄
:param sex: 性别 默认是男性
:return: 个人信息
"""
print(f"您的名字是:{name},年龄是:{age},性别是:{sex}")
user_info("李四", 20)
user_info("王五", 30, sex="女")
结果:
您的名字是:李四,年龄是:20,性别是:男
您的名字是:王五,年龄是:30,性别是:女
不定长参数:
不定长参数也叫可变参数,用于不确定调用的时候会传递多少个参数(不传参也可以)的场景。
作用:当调用函数时不确定参数个数时,可以使用不定长参数
不定长参数的类型:
- 位置传递 *args规划用法
def user_info(*args): print(f"args参数的类型是{type(args)},内容是:{args}") user_info("李四") user_info("王五", 30) 结果: args参数的类型是<class 'tuple'>,内容是:('李四',) args参数的类型是<class 'tuple'>,内容是:('王五', 30)
注意: 传进的所有参数都会被args变量收集,它会根据传进参数的位置合并为一个元组(tuple), args是元组类型,这就是位置传递
- 关键字传递 **kwargs规划用法
def user_info(**kwargs):
print(f"kwargs参数的类型是{type(kwargs)},内容是:{kwargs}")
user_info(name="王五", age=18, sex="男") # {key:value}
user_info(name="王五", age=18, sex="男", id=102)
结果:
kwargs参数的类型是<class 'dict'>,内容是:{'name': '王五', 'age': 18, 'sex': '男'}
kwargs参数的类型是<class 'dict'>,内容是:{'name': '王五', 'age': 18, 'sex': '男', 'id': 102}
注意: 参数时“键=值”形式的形式情况下,所以的“键=值”都会被kwargs接受,同时会根据“键=值”组成字典 args是元组类型,这就是位置传递
匿名函数
1.函数本身是可以作为参数,传入另一个函数中进行使用的。
2.将函数传入的作用在于:传入计算逻辑,而非传入数据。
# 定义一个函数,接收另一个函数作为传入参数
def test_func(compute):
result = compute(1, 5) # 确定computer是函数
print(f"computer参数的类型是:{type(compute)}")
print(f"计算结果:{result}")
# 定义一个函数,准备作为参数传入另一个函数
def compute(x, y):
return x + y
# 调用,并传入函数
test_func(compute)
结果:
computer参数的类型是:<class 'function'>
计算结果:6
lambda 匿名函数
函数的定义中
- def关键字,可以定义带有名称的函数
- lambda关键字,可以定义匿名函数(无名称)
有名称的函数,可以基于名称重复使用。
无名称的匿名函数,只可临时使用一次
无名称的匿名函数,只可临时使用一次
匿名函数定义语法:
- lambda 传入参数:函数体(一行代码)
- lambda 是关键字,表示定义匿名函数
- 传入参数表示匿名函数的形式参数,如:xy表示接收2个形式参数函数体,就是函数的执行逻辑,要注意:只能写一行,无法写多行代码
定义语法:
lambda 传入参数:函数体(一行代码)
# 通过lambda关键字,传入一个一次性使用的lambda匿名函数
def test_func(compute):
result = compute(1, 6)
print(result)
# 使用def和使用lambda,定义的函数功能完全一致,只是使用lambda关键字定义的函数是匿名的,无法二次使用
# 无法多行
test_func(lambda x, y: x - y)
test_func(lambda x, y: x + y)
结果:
计算结果:6
-5
注意:
- 匿名函数用于临时构建一个函数,只用一次的场景
- 匿名函数的定义中,函数体只能写一行代码,如果函数体要写多行代码,不可用lambda匿名函数,应使用def定义带名函数