python系列教程136——带星号的变量名
Posted 人工智能AI技术
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python系列教程136——带星号的变量名相关的知识,希望对你有一定的参考价值。
朋友们,如需转载请标明出处: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
以上是关于python系列教程136——带星号的变量名的主要内容,如果未能解决你的问题,请参考以下文章
python 函数参数的传递(参数带星号的说明) 元组传递 字典传递