商城首页欢迎来到中国正版软件门户

您的位置:首页 >Python 星号参数 \*args \*\*kwargs 详解

Python 星号参数 \*args \*\*kwargs 详解

  发布于2026-03-01 阅读(0)

扫一扫,手机访问

Python 星号表达式 *args **kwargs 原理

Python 中的 *args**kwargs 不是特殊语法糖,而是函数调用与定义时的解包(unpacking)和收集(packing)机制,核心在于“星号操作符对可迭代对象和字典的拆解规则”。

函数定义时:*args 收集多余的位置参数

当在形参列表中使用 *args,Python 会把所有未被前面形参匹配的**位置参数**打包成一个 tuple,赋值给 args 变量。

  • def f(a, *args): —— a 接收第一个位置参数,其余全进 args(哪怕没传,args 也是空 tuple)
  • *args 必须写在普通形参之后、**kwargs 之前,且一个函数最多只能有一个 *args
  • 名字不固定,*rest*xs 都可以,args 只是约定俗成

函数定义时:**kwargs 收集多余的关键字参数

当使用 **kwargs,Python 把所有未被前面形参名匹配的**关键字参数**打包成一个 dict,键为参数名,值为对应实参值。

  • def f(a, **kwargs): —— a 必须用关键字或位置传;其他关键字参数(如 b=2, c=3)全进 kwargs
  • **kwargs 必须放在形参列表最末,且只能有一个
  • 传入的关键字参数名必须是合法标识符(不能是数字、表达式等)

函数调用时:* 和 ** 是解包操作符

星号在调用处作用相反:它们把容器“打开”,把其中元素作为独立参数传入。

  • *a_list 等价于把列表每个元素当作一个位置参数展开:f(*[1,2,3])f(1,2,3)
  • **a_dict 把字典键值对作为关键字参数展开:f(**{'x':10, 'y':20})f(x=10, y=20)
  • 解包对象必须是可迭代的(*)或映射类型(**),否则报 TypeError
  • 可混合使用:f(1, *[2,3], x=4, **{'y':5, 'z':6})f(1,2,3,x=4,y=5,z=6)

本质统一:都是“参数传递协议”的语法支持

*args**kwargs 在定义端是“收集”,在调用端是“解包”,二者共享同一套底层机制——Python 解析器根据星号数量和上下文自动切换语义。

  • 它们不是变量类型,也不改变参数本身;只是告诉解释器:“这里要动态处理参数流”
  • 装饰器、代理函数、通用接口封装都依赖这套机制实现灵活性
  • 从 Python 3.5 起,* 还可用于解包到字面量中(如 [1, *a, 2]),但函数参数场景仍是最经典用例
本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注