Python函数参数传递的几种形式
- 前言
- 位置传参
- 序列传参(单星号元组传参)
- 关键字传参
- 字典关键字传参(双星号字典传参)
- 混合传参
- 函数的缺省参数
- 结束
前言
莫听穿林打叶声,何妨吟啸且徐行。竹杖芒鞋轻胜马,谁怕?一蓑烟雨任平生。❤️
位置传参
位置传参:实际调用参数(实参) 的对应关系与形式参数(形参)的对应关系是按位置来依次对应的。
def fx(a, b, c):
pass
fx(1, 2, 3)
序列传参(单星号元组传参)
序列传参:在函数调用过程中,用 * 将序列拆解(或收集)后按位置进行传递的传参方式,。
def fx(a, b, c):
pass
t = (1, 2, 3)
fx(*t)
def fx(*args):
print(args[1])
fx(1, 2, 3, 4)
结果为:
2
关键字传参
关键字传参:实参和形参按名称进行匹配。
def fx(a, b, c):
pass
fx(c = 1, a = 2, b = 3)
def fx(address, sex, *, name, age): # *后面代表这个参数调用时必须使用关键字的方式
print(address, sex, name, age)
fx("上海", "男", name="张三" ,age=18)
def fx(address, sex, *, name, age): # *后面代表这个参数调用时必须使用关键字的方式
print(address, sex, name, age)
fx("上海", "男", **{"name":"张三","age":18})
字典关键字传参(双星号字典传参)
字典关键字传参:实参为字典,用**拆解字典(或收集关键字)后再进行关键字传参。
def fx(a, b, c):
pass
d = {'c': 33, 'b': 22, 'a': 11}
fx(**d)
def fx(**kwargs):
print(kwargs)
print(kwargs['c'])
fx(a=1, b="b", c=[1, 2, 3], d=True)
结果为:
{'a': 1, 'b': 'b', 'c': [1, 2, 3], 'd': True}
[1, 2, 3]
说明:
字典的键名和形参名必须一致;
字典的键名必须为字符串;
字典的键名要在形参中存在。
混合传参
混合传参实参顺序:通常位置传参和序列传参先传递,其次是关键字传参和字典关键字传参。
def fx(a, b, c, d, e, f):
pass
fx(10, *(20, 30), e=50, **{'d':40, 'f':60})
混合传参形参顺序:自左至右为: 1. 位置形参;2. 星号元组形参;3. 命名关键字形参;4. 双星号字典形参。
def fx(a, b, *args, c, **kwargs):
print(c)
print(kwargs)
fx(100, 200, 300, 400,*"AB", **{'d':"D"}, c=100)
结果为:
100
{'d': 'D'}
fx(100, 200, 300, 400,*"AB", **{'d':"D", "c":"C"}, e=100)
结果为:
C
{'d': 'D', 'e': 100}
函数的缺省参数
函数的缺省参数:形参的默认值。
说明:
缺省参数在形参末尾依次存在;
缺省参数可以有0个,1个,多个,甚至全部都有缺省参数;
缺省参数的值同函数的生命周期一致。
def fx(name, age=1, address="不详"):
print("我叫", name, '我今年:', age,'岁, 家庭住址:', address)
fx("张飞", 30, "中原")
fx("关羽", 35)
fx("赵云")
结果为:
我叫 张飞 我今年: 30 岁, 家庭住址: 中原
我叫 关羽 我今年: 15 岁, 家庭住址: 不详
我叫 赵云 我今年: 1 岁, 家庭住址: 不详
def fx(a, lst=[]): # 此示例来示意fn函数中lst绑定的缺省参数的列表的生命周期
lst.append(a)
print(lst)
L = [1,2,3,4]
fx(5, L)
fx(6, L)
fx(1)
fx(2)
结果为:
[1, 2, 3, 4, 5]
[1, 2, 3, 4, 5, 6]
[1]
[1, 2]
结束
我很荣幸你能看到这篇博客,个人水平有限,欢迎讨论留言。如果对您有启发,不妨点赞、分享和收藏。❤️