从一个例子看Python3.x中序列解包

来源:互联网 发布:企业名录数据库 编辑:程序博客网 时间:2024/05/17 11:56

假如一个字符串'ABCDEFGH',要输出下列格式:


即: 每次取出第一个作为首,然后的字符串拆成列表,放置在后面,最后成上面的输出:

一般的处理是:

>>> s = 'ABCDEFGH'>>> while s:  front, s = s[0], list(s[1:])  print(front, s)A ['B', 'C', 'D', 'E', 'F', 'G', 'H']B ['C', 'D', 'E', 'F', 'G', 'H']C ['D', 'E', 'F', 'G', 'H']D ['E', 'F', 'G', 'H']E ['F', 'G', 'H']F ['G', 'H']G ['H']H []
备注:

1.将切片中索引为0的字符赋值给front

2.将切片中索引为1之后字符再赋值给s

3.用list函数将字符串转变为列表

4.用while循环来s来判断,为空,则退出循环

上面的处理,可以用序列解包的方法会来处理,并好理解。 序列解包是Python 3.0之后出现,之前的版本一般赋值的时候,一定要对等,才能正常赋值,比如说:

>>> a, b, c = (1, 2, 3)>>> a, c(1, 3)>>> [a, b, c] = (1, 2, 3)>>> a, c(1, 3)>>> a, b, c = 'SON'         # 刚好三个字符的字符串>>> a, c('S', 'N')
如果是不对等的情况下,是会报错的: too many values to unpack
>>> a, b = 'SON'Traceback (most recent call last):  File "<pyshell#42>", line 1, in <module>    a, b = 'SON'ValueError: too many values to unpack (expected 2)
3.0出现了解包,一切就简单多了,如果我不之后字符有多少个时候,都可以如此:
>>> a, *b = 'BOOK'>>> a, b('B', ['O', 'O', 'K'])>>> *a, b = 'BOOK'>>> a, b(['B', 'O', 'O'], 'K')

上面就是序列解包,在赋值时无疑更方便,适用性更强!运用序列解包的功能重写上面的代码:


从上面可以看出: 代码更简洁,也更好理解了!








原创粉丝点击