利用python进行数据分析学习笔记ch03.1

3.1数据结构和序列

元组

tup = 4, 5, 6
tup

组成元素是元组的元组

nested_tup=(4,5,6),(7,8)
nested_tup

使用tuple函数将任意序列或迭代器转换为元组

tuple([4,0,2])
tup=tuple('string')
tup

python中的序列索引是从0开始的

tup[0]

元组一旦创建,各个位置上的对象是无法被修改的

tup=tuple(['foo',[1,2],True])
tup[2]= Flase

如果元组中的一个对象是可变的,例如列表,可以再内部进行修改,这里的修改其实是对tup这个元组中第二位的元组[1,2]进行了修改

tup[1].append(3)
tup

可以使用+号链接来生成更长的元组,这里bar之后还要添加一个逗号,如果不添加的话会报错。

(4,None,'foo')+(6,0)+('bar',)

#将元组乘以整数,会和列表一样,生成含有多份拷贝的元组

('foo','bar')*4

#对象本身并没有复制,只是指向他们的引用进行了复制

3.1.1.1元组拆包

如果想要将元组型的表达式赋值给变量,Python会对等号右边的值进行拆包

tup = (4, 5, 6)
a, b, c = tup
c

这里相当于先将(4,5,6)复制给tup,然后a,b,c与tup这个变量进行绑定位置一一对应
即使是嵌套的元组也可以进行拆包

tup = 4, 5, (6, 7)
a, b, (c, d) = tup
d

使用这个功能能够轻易交换变量名。

a, b = 1, 2
a
b

拆包常用场景遍历元组或列表组成的序列

seq = [(1, 2, 3), (4, 5, 6), (7, 8, 9)]
for a, b, c in seq:
    print('a={0},b={1},c={2}'.format(a, b, c))

个人理解,这个for循环是定义a,b,c分别为一个元组的第一二三个元素,从seq元组中的第一个第二个第三个元组依次取值

更为高级的拆包方法
values=1,2,3,4,5
a,b,*rest=values
a,b
rest

rest部分有时是想要去除的数据,rest这个变量名并没有特指的意义,为了方便,很多python编程者会使用_来表示不想要的变量

a,b,*_=values
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值