Python函数返回多个值本质是返回元组,可直接用逗号分隔变量解包;需确保变量数与元组长度一致,支持星号捕获、嵌套解包、下划线忽略及原子交换。

函数返回多个值时直接解包成变量
Python 函数天然支持返回多个值,本质是返回一个元组,但你不需要显式写 tuple 或调用 tuple()。只要用逗号分隔多个表达式,Python 就自动打包成元组;接收时用对应数量的变量名加逗号,就能自动解包。
常见错误是误以为返回的是“多个独立值”,试图用单个变量接收,结果得到一个元组对象,后续操作报 TypeError: 'tuple' object is not callable 或属性访问失败。
- 正确写法:
name, age, city = get_user_info()(假设get_user_info()返回('Alice', 30, 'Beijing')) - 变量数必须与元组长度严格一致,否则触发
ValueError: too many values to unpack或not enough values to unpack - 可用星号
*捕获剩余项,如a, *b, c = [1,2,3,4,5]→a=1, b=[2,3,4], c=5,但仅限一次使用且不能在开头单独用*b
一行交换两个变量的值无需临时变量
传统语言常靠第三个变量中转,Python 中直接用元组解包即可完成原子交换,语义清晰且无副作用。
原理是右侧先构造元组(如 (y, x)),再整体解包赋值给左侧变量序列。不是“先赋 x=y 再赋 y=x”,所以不会丢失原始值。
立即学习“Python免费学习笔记(深入)”;
- 标准写法:
x, y = y, x—— 这比temp = x; x = y; y = temp更简洁安全 - 可用于任意可变/不可变类型:数字、字符串、列表引用、自定义对象等
- 注意:若写成
x, y = y, x + 1,右侧的x是原值,不是刚被赋过的值,这点和多行赋值逻辑一致
嵌套结构解包要对齐层级
当函数返回的是嵌套元组或混合结构(如元组含列表、字典),解包需按实际嵌套形状声明变量模式,否则会报 ValueError: not enough values to unpack 或类型错误。
例如 def get_point(): return (10, (20, 30)),想分别拿到 x、y、z,不能写 x, y, z = get_point()(只有两个元素),而应写 x, (y, z) = get_point()。
- 支持多层括号匹配:
a, (b, c), d = (1, (2, 3), 4) - 字典不支持直接解包,但可用
**解包到函数调用中;若硬要从字典取键值对,得先转成list(d.items())再解包 - 生成器或迭代器也可解包,但会被消耗一次,多次使用需转为
list或重新创建
解包时忽略某些值用下划线占位
并非所有返回值都需要命名,尤其调用只关心其中一两个字段的函数时。用单个下划线 _ 表示“这里有个值但我不要”,既避免命名污染,又明确传达意图。
注意:下划线只是普通变量名,不会跳过值;它只是约定俗成的“丢弃变量”,Python 不特殊处理。若需真正跳过(比如前 N 项),仍得用 * 星号表达式。
- 忽略单个值:
status, _, message = http_request() - 忽略多个连续值:
first, *_, last = [1,2,3,4,5]→first=1, last=5 - 不推荐连用多个下划线(如
_, __, ___),语义模糊且易出错
最易被忽略的是解包目标与源结构的“形状一致性”——它不看类型,只看嵌套层次和元素数量。哪怕全是 None 或空容器,只要结构不对,运行时就崩。调试时建议先 print(type(ret), len(ret), ret) 确认返回值真实形态,再写解包语句。











