朋友们,如需转载请标明出处:https://blog.csdn.net/jiangjunshow

声明:在人工智能技术教学期间,不少学生向我提一些python相关的问题,所以为了让同学们掌握更多扩展知识更好地理解AI技术,我让助理负责分享这套python系列教程,希望能帮到大家!由于这套python教程不是由我所写,所以不如我的AI技术教学风趣幽默,学起来比较枯燥;但它的知识点还是讲到位的了,也值得阅读!想要学习AI技术的同学可以点击跳转到我的教学网站。PS:看不懂本篇文章的同学请先看前面的文章,循序渐进每天学一点就不会觉得难了!

我们已经知道,序列赋值通常要求左边的项数与右边的项数完全一致。如果长度不同的话,将会得到一个错误:

C:\misc> c:\python30\python

>>> seq = [1,2,3,4]

>>> a,b,c,d = seq

>>> print(a,b,c,d)

1 2 3 4

>>> a,b = seq

ValueError: too many values to unpack

在Python 3.0中,我们可以使用带单星号的变量名来避免这个问题。在如下的代码中,a匹配序列中的第一项,b匹配剩下的内容:

>>> a,*b = seq

>>> a

1

>>> b

[2,3,4]

当使用一个带星号的变量名的时候,左边的目标中的项数不需要与主体序列的长度匹配。实际上,带星号的变量名可以出现在目标中的任何地方。例如,在下面的代码中,b匹配序列中的最后一项,a匹配最后一项之前的所有内容:

>>> *a,b = seq

>>> a

[1,2,3]

>>> b

4

当带星号的变量名出现在中间,它收集其他列出的变量名之间的所有内容。因此,在下面的代码中,第一项和最后一项分别赋给了a和c,而b获取了二者之间的所有内容:

>>> a,*b,c = seq

>>> a

1

>>> b

[2,3]

>>> c

4

这种语法对于任何序列类型都有效,而不只是对列表有效。下面代码中,它分解了一个字符串中的字符:

>>> a,*b = 'spam'

>>> a,b

('s',['p','a','m'])

>>> a,*b,c = 'spam'

>>> a,b,c

('s',['p','a'],'m')

带星号的变量名总是会被赋值一个列表,即使只有一个元素:

>>> seq

[1,2,3,4]




>>> a,b,c,*d = seq

>>> print(a,b,c,d)

1 2 3 [4]

另外,如果没有剩下的内容可以匹配带星号的变量名,它会赋值一个空的列表:

>>> a,b,c,d,*e = seq

>>> print(a,b,c,d,e)

1 2 3 4 []




>>> a,b,*e,c,d = seq

>>> print(a,b,c,d,e)

1 2 3 4 []

如果有多个带星号的变量名将引发错误:

>>> a,*b,c,*d = seq

SyntaxError: two starred expressions in assignment
Logo

CSDN联合极客时间,共同打造面向开发者的精品内容学习社区,助力成长!

更多推荐