args接收任意位置参数并打包为tuple,kwargs接收任意关键字参数并打包为dict;二者顺序固定为必选参数→args→kwargs,且支持解包调用。

Python 中的 *args 和 **kwargs 是处理可变数量参数的核心机制,它们让函数更灵活、复用性更强。关键不在于记住语法,而在于理解“什么时候该用、怎么传、怎么接”。
什么是 *args:接收任意多个位置参数
*args 用于捕获调用时传入的**多余位置参数**(即没有对应形参名的参数),自动打包成一个 tuple。它必须写在普通参数之后、**kwargs 之前。
示例:
def greet(name, *hobbies): print(f"Hi {name}!") print("Your hobbies:", hobbies) # hobbies 是 tuple <p>greet("Alice", "reading", "swimming", "coding")</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/00968c3c2c15" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">Python免费学习笔记(深入)</a>”;</p><h1>输出:</h1><h1>Hi Alice!</h1><h1>Your hobbies: ('reading', 'swimming', 'coding')</h1>
登录后复制
- 如果只传必需参数,
*args接收到的是空 tuple() - 不能用关键字方式传给
*args参数(如greet(name="Bob", "tennis")会报错) - 名字不固定,
*args只是约定俗成;写成*things或*rest也合法
什么是 **kwargs:接收任意多个关键字参数
**kwargs 捕获所有**未被显式声明的关键字参数**,自动打包成一个 dict。它必须放在参数列表最后。
创客贴设计,一款智能在线设计工具,设计不求人,AI助你零基础完成专业设计!
213 示例:
def profile(name, **info): print(f"Name: {name}") print("Extra info:", info) # info 是 dict <p>profile("Tom", age=30, city="Shanghai", job="Engineer")</p><h1>输出:</h1><h1>Name: Tom</h1><h1>Extra info: {'age': 30, 'city': 'Shanghai', 'job': 'Engineer'}</h1>
登录后复制
- 键必须是合法标识符(不能是数字或表达式),值可以是任意类型
- 若没传额外关键字参数,
**kwargs得到的是空字典{} - 和
*args一样,**kwargs是命名习惯,实际可用**options等
组合使用:*args + **kwargs 的典型顺序
当函数既要支持任意位置参数、又要支持任意关键字参数时,标准写法是:
def func(required, *args, **kwargs): ...
登录后复制
这个顺序不可颠倒:必选参数 → *args → **kwargs。Python 靠这个顺序区分参数类型。
-
required必须提供(除非有默认值) -
*args接收剩下未匹配的位置参数 -
**kwargs接收所有未匹配的关键字参数 - 常见于装饰器、封装底层函数、API 适配层等场景
实际技巧:解包传递参数
*args 和 **kwargs 不仅用于定义函数,也常用于“解包”已有的数据结构来调用函数。
- 用
*解包序列(list/tuple)作为位置参数:func(*my_list) - 用
**解包字典作为关键字参数:func(**config_dict) - 可混合使用:
func(a, *b, c=10, **d) - 这是实现“参数透传”的基础,比如写一个通用日志装饰器,不关心被装饰函数收什么参数
以上就是Python可变参数如何使用_*args与**kwargs讲解【指导】的详细内容,更多请关注php中文网其它相关文章!
相关标签:
微信扫一扫打赏
支付宝扫一扫打赏
