• 注册
当前位置:1313e > python >正文

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 = 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

本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 162202241@qq.com 举报,一经查实,本站将立刻删除。

最新评论

欢迎您发表评论:

请登录之后再进行评论

登录