Python基础笔记(二)--元组拆包

先看一个简单的例子:

student1 = ("David", 90)
stuName, stuScore = student1;
print('Name: %s, Score: %s' %(stuName, stuScore))

其中第二行代码就是一个简单的元组拆包,它将一个学生对象按照Name, Score拆分,并赋值给stuName, stuScore这两个变量,这种简单的元组拆包叫做平行赋值
还可以用*将一个可迭代对象拆分成函数的参数:

t = [88,20]
print(*t)
print(divmod(*t))

产生的结果是:
88 20
(4, 8)

除此之外,可以用*来处理剩下的元素:

a,b,*rest = range(10)
print(a,b,rest)

这时a = 0; b = 1; rest = [2,3,4,5,6,7,8,9]

a,*rest,b = range(10)
print(a,rest,b)

这时a = 0; rest = [1,2,3,4,5,6,7,8]; b = 9

a, b, *rest = range(3)
print(a,b,rest)

这时a = 0; b = 1; rest = [2]

a, b, *rest = range(2)
print(a,b,rest)

这时a = 0; b = 1; rest = []
但是不用*来表示剩余元素时,编译过程就会报错:

a, b, rest = range(10)
print(a,b,rest)

Traceback (most recent call last):
  File "D:/PythonWorkSpace/FluentPython/c2/c2-7.py", line 21, in <module>
    a, b, rest = range(10)
ValueError: too many values to unpack (expected 3)

总结一下,元组拆包可以应用到任何可迭代的对象上,唯一的硬性要求是,被拆包的对象的元素数量必须和接受这些元素的元组的空档数一致,除非用*来表示忽略多余的元素。

嵌套元组拆包

students = [
    ('David', 'male', (100, 90)), 
    ('Nancy', 'female', (95,88)),
    ('Joe', 'male', (80,95)),
    ('Lucy', 'female', (100,83)),
]
print('{:6} | {:^6} | {:^6}'.format('', 'score1', 'score2'))
fmt = '{:6} | {:6} | {:6}'
for name, sex,(score1, score2) in students: 
    if score1 + score2 >= 180:  
        print(fmt.format(name, score1, score2))

students列表是嵌套式的,分别代表姓名,性别,成绩1,成绩2,最后输出:

       | score1 | score2
David  |    100 |     90
Nancy  |     95 |     88
Lucy   |    100 |     83
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 最近在写个性化推荐的论文,经常用到Python来处理数据,被pandas和numpy中的数据选取和索引问题绕的比较...
    shuhanrainbow阅读 4,595评论 6 19
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,991评论 19 139
  • 1. 关于诊断X线机准直器的作用,错误的是()。 (6.0 分) A. 显示照射野 B. 显示中心线 C. 屏蔽多...
    我们村我最帅阅读 10,834评论 0 5
  • 落后青年阅读 270评论 1 1
  • 昨天男闺蜜说,女生有时候可以软弱点,别事事都要强,这样更容易得到幸福。这话没错,可是没有遇到合适的人之前,软弱给谁...
    srily206阅读 211评论 0 0