python-带星号的参数**kwargs

本文详细介绍了Python函数中各种参数的定义形式与使用方法,包括普通参数、带默认值的参数、带一个星号的参数以及带两个星号的参数,并通过实例展示了它们的应用。

在深度学习模型代码中,经常能看到带星号的参数,如 def __init__(self, in_channels, **kwargs),这类参数和普通参数有什么不同呢?

python函数参数定义主要有以下几种形式:

1. function(arg1, arg2....)

这是最常见的参数定义形式,一个函数可以定义任意数量的参数,每个参数用逗号隔开。

在调用时,函数名后的参数个数需要与定义时的数目一致(形参数等于实参数),并且要求顺序一一对应。例如:

def fun1(x, y, z):
    return x+y+z

fun1(3, 5, 7)      #参数x=3, y=5, z=7, 返回值为15 (括号里的参数个数必须为3)

 这里括号里的参数必须为三个,即对应x, y,z三个值,如果是fun1(1)或fun1(1,2)等,就会报错。

2. function(arg1, arg2=value2, args3=value3....)

这类形式在第一种搞得基础上为参数提供了默认值。

def fun2(x, y, z=3):
    return x*y*z

fun2(2, 5)         #参数x=2, y=5, z=3, 返回值为30 (括号里参数个数为2时,则z选择默认值3)
fun2(2, 5,2)      #参数x=2, y=5, z=2, 返回值为20 (可以通过参数传递修改默认值)

调用该函数时,如果带有默认值的参数省略,则取默认值;如果传递了该位置的参数,则使用传递的参数值。

注:在定义函数时,无默认值的参数必须在有默认值参数的前面,即有默认值的参数后面必须都是带有默认值的。def fun(a=2, b,c)这种是会报错的。

3. function(arg1, *args2....)

带一个*号的参数以元组tuple的形式存放参数。

当函数传递的参数量不确定时,可以采用这种形式。无论参数量多少,在函数内部都被存放在以形参名为标识符的tuple中。

def fun3(a, *args):
    print("a:", a)
    print("args:", args)

fun3(2,3,4,5,6)        # 传递的实参数大于形参数

## 输出
a: 2
args: (3, 4, 5, 6)
def fun3(a, *args):
    print("a:", a)
    print("args:", args)

fun3(2,(3,4,5,6,7))      # 带星号的参数位置直接传递元组类型

## 输出
a: 2
args: ((3, 4, 5, 6, 7),)    # 单个元素的元组后面需要加逗号

4. function(arg1, **kwargs2...)

带两个*号的参数以字典dict的形式存放参数。在调用函数时,需采用 (arg1=value1,arg2=value2) 这样的形式,前面的arg和后面的value就形成了键值对。

def fun4(a, **kwargs):
    print("a:", a)
    print("kwargs:", kwargs)

fun4(2, b=2, c=3, d=4, e=5)

## 输出
a: 2
kwargs: {'b': 2, 'c': 3, 'd': 4, 'e': 5}

当然以上四种形式是可以同时存在的,但是应注意参数的顺序。在调用时,上述四种方式的优先级是依次降低的,先1,后2,再3,最后4。

def fun5(a, b=10, *args, **kwargs):
    print("a:", a)
    print("b:", b)
    print("args:", args)
    print("kwargs:", kwargs)


fun5(3, 2, 1, 4, c=6, d=5, e=2)

## 输出
a: 3
b: 2
args: (1, 4)
kwargs: {'c': 6, 'd': 5, 'e': 2}

如果单独出现星号 *,则星号 * 后的参数必须用关键字传入:

<think>我们正在讨论Python中的*args和**kwargs参数机制。用户希望理解这两个参数的含义和用法。 根据引用资料,我们可以总结如下: 1. *args用于接收任意数量的位置参数(非关键字参数),在函数内部作为一个元组(tuple)处理。 2. **kwargs用于接收任意数量的关键字参数(键值对),在函数内部作为一个字典(dict)处理。 3. 参数顺序:在函数定义时,必须遵循常规参数、*args、**kwargs的顺序。 此外,引用中还提到: - 在函数体内,使用args和kwargs时不需要加星号(去掉*),因为星号只是在定义函数时用来表示参数类型的。 - 可以通过示例代码来加深理解。 现在,我将按照系统指令的要求,用中文清晰地解释*args和**kwargs,并生成相关问题。 注意:在回答中,行内数学表达式不需要,但需要遵循LaTeX语法正确的要求(虽然这里没有数学公式,但要确保代码块正确)。另外,回答最后要生成相关问题。 由于用户问题不涉及数学公式,因此我们主要使用代码块和文字说明。 </think>### Python *args和**kwargs参数详解 在Python中,`*args`和`**kwargs`是处理函数可变参数的强大机制,遵循特定语法规则: #### 1. 核心概念 - **`*args`**(可变位置参数- 接收任意数量的**位置参数** - 在函数内部转为**元组(tuple)** 类型 - 示例: ```python def sum_numbers(*args): return sum(args) # args类型为tuple print(sum_numbers(1, 2, 3)) # 输出:6 ``` - **`**kwargs`**(可变关键字参数- 接收任意数量的**关键字参数** - 在函数内部转为**字典(dict)** 类型 - 示例: ```python def print_info(**kwargs): for key, value in kwargs.items(): print(f"{key}: {value}") print_info(name="Alice", age=30) # 输出:name: Alice \n age: 30 ``` #### 2. 参数顺序规则(关键!) 函数定义时必须严格遵守顺序: 1. 常规位置参数 2. `*args`参数 3. `**kwargs`参数 公式:$常规参数 → *args → **kwargs$ 错误顺序会导致语法错误 #### 3. 组合使用示例 ```python def process_data(start, *args, **kwargs): print(f"起始值: {start}") print(f"位置参数元组: {args}") print(f"关键字参数字典: {kwargs}") # 调用示例 process_data(10, 20, 30, 40, name="Bob", role="Admin") ``` 输出: ``` 起始值: 10 位置参数元组: (20, 30, 40) 关键字参数字典: {'name': 'Bob', 'role': 'Admin'} ``` #### 4. 特殊调用技巧 - **解包序列**: ```python numbers = (2, 3, 4) func(1, *numbers) # 等价于 func(1, 2, 3, 4) ``` - **解包字典**: ```python params = {'a': 5, 'b': 6} func(**params) # 等价于 func(a=5, b=6) ``` #### 5. 应用场景 - 编写通用装饰器 - 继承中的方法重写 - 参数传递桥接 - 动态API调用 - 数据处理管道 > 关键提示:函数定义中的`*`和`**`仅声明参数类型,函数内部使用时需去掉星号直接使用`args/kwargs`[^1][^4]。参数顺序错误是常见错误来源[^2][^3]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小李AI飞刀^_^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值