洞察探讨小游戏SDK接入的最佳实践以及对企业跨平台开发的优势
963
2022-10-01
python系列教程136——带星号的变量名
我们已经知道,序列赋值通常要求左边的项数与右边的项数完全一致。如果长度不同的话,将会得到一个错误:
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 = seqValueError: too many values to unpack
在Python 3.0中,我们可以使用带单星号的变量名来避免这个问题。在如下的代码中,a匹配序列中的第一项,b匹配剩下的内容:
>>> a,*b = seq>>> a1>>> b[2,3,4]
当使用一个带星号的变量名的时候,左边的目标中的项数不需要与主体序列的长度匹配。实际上,带星号的变量名可以出现在目标中的任何地方。例如,在下面的代码中,b匹配序列中的最后一项,a匹配最后一项之前的所有内容:
>>> *a,b = seq>>> a[1,2,3]>>> b4
当带星号的变量名出现在中间,它收集其他列出的变量名之间的所有内容。因此,在下面的代码中,第一项和最后一项分别赋给了a和c,而b获取了二者之间的所有内容:
>>> a,*b,c = seq>>> a1>>> b[2,3]>>> c4
这种语法对于任何序列类型都有效,而不只是对列表有效。下面代码中,它分解了一个字符串中的字符:
>>> 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 = seqSyntaxError: two starred expressions in assignment
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~