python解包是语言级结构化赋值机制,核心为结构匹配:基础解包要求变量与元素数量一致;星号表达式可捕获剩余项;嵌套解包需左右结构形状一致;函数调用中和*分别展开位置与关键字参数。

Python 的 unpacking(解包)不是语法糖,而是语言级的结构化赋值机制,核心在于“匹配结构”而非单纯拆分序列。
基础解包:序列与变量一一对应
最常见的是将可迭代对象(如列表、元组)的元素依次赋给等数量的变量:
- a, b, c = [1, 2, 3] → a=1, b=2, c=3;左侧变量数必须等于右侧元素数
- 支持任意可迭代对象:x, y = "ab"、m, n = {1, 2}(集合无序,但解包仍成立)
- 若数量不匹配,抛出 ValueError: too many values to unpack 或 not enough values
星号表达式:捕获剩余项(PEP 3132)
用 * 标记一个变量,让它接收“多余”的元素,使解包更灵活:
- a, *b, c = [1, 2, 3, 4, 5] → a=1, b=[2,3,4], c=5;* 可出现在任意位置,且最多只能有一个
- *head, tail = range(5) → head=[0,1,2,3], tail=4
- first, *_, last = data 中 _ 是惯用占位符,表示忽略中间所有值(实际仍会构建列表)
嵌套解包:结构对齐是关键
只要左右两侧结构形状一致,就能嵌套解包,适用于元组、列表甚至混合结构:
立即学习“Python免费学习笔记(深入)”;
- (x, y), (u, v) = [(1, 2), (3, 4)] → x=1, y=2, u=3, v=4
- [a, [b, c]] = [1, [2, 3]] → a=1, b=2, c=3;注意中括号也参与结构匹配
- 失败示例:(i, j), k = (1, 2), 3 合法;但 (i, j), k = (1, 2, 3) 报错——左侧是“一个二元组 + 一个变量”,右侧是一个三元组,结构不匹配
函数调用中的解包:* 和 ** 的作用
解包不仅用于赋值,也活跃在函数调用中,用于展开参数:
- *iterable 将可迭代对象展开为位置参数:print(*[1, 2, 3]) 等价于 print(1, 2, 3)
- **mapping 将字典展开为关键字参数(键必须是字符串):func(**{'a': 1, 'b': 2}) ≡ func(a=1, b=2)
- 可混用:func(x, *args, y=10, **kwargs) 遵循标准调用顺序规则










