为什么我不能使用加星标的表达式?

我的代码

$ python
Python 3.5.2 |Continuum Analytics, Inc.| (default, Jul 2 2016, 17:53:06)
[GCC 4.4.7 20120313 (Red Hat 4.4.7-1)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> a = (1, 2)
>>> '%d %d %d' % (0, *a)
'0 1 2'
>>> '%d %d %d' % (*a, 3)
'1 2 3'
>>> '%d %d' % (*a)
File "", line 1
SyntaxError: can't use starred expression here
>>>
我的问题,为什么?

用更严肃的语气:我想要一个答案或参考,详细说明使用加星标的表达式的所有来龙去脉,因为碰巧我有时会对它的行为感到惊讶......

附录
为了反映我的问题后立即出现的一些启发性评论,我添加了以下代码

>>> '%d %d' % (, *a)
File "", line 1
'%d %d' % (, *a)
^
SyntaxError: invalid syntax
>>> '%d %d' % (*a,)
'1 2'
>>>
(我(, a)在发布原始问题之前尝试过该部分,但我省略了它,因为错误与主演无关。)

在 python ≥ 3.5 中有一种语法“可以正常工作”,但我还是希望得到一些理解。

已邀请:
这是因为:

(a)
只是一个被括号包围的值。它不是一个新的元组对象。所以你的表达:

>>> '%d %d' % (*a)
将被翻译成:

>>> '%d %d' % * a
这在 python 语法方面显然是错误的。

为了创建一个新的元组,用一个表达式作为初始化器,你需要,在它后面添加一个“ ”:

>>> '%d %d' % (*a,)
注意:除非a是生成器,在这种特殊情况下,您只需键入:

>>> '%d %d' % a
另外,如果我可以提出一些建议:您可以开始使用新样式的格式化表达式。他们都是伟大的!

>>> "{} {}".format(*a)
你可以阅读更多关于他们在那些牛逼w ^ ō Python文档中的段落,也有这个伟大的网站。上面的行使用下面描述的参数解包机制。

更新:从 python 3.6 开始,您还可以使用字符串插值 - f-strings!这些在PEP-498 中有描述,一些示例可以在Python 文档中找到。

加星标的表达式
带星号的表达式除了创建新的列表/元组/字典之外,还有更多用途。其中大部分在PEP 3132和PEP 448 中有描述。

所有这些都归结为两种:

R值拆包:

>>> a, *b, c = range(5)
# a = 0
# b = [1, 2, 3]
# c = 4
>>> 10, *range(2)
(10, 0, 1)
可迭代/字典对象初始化(请注意,您也可以在列表中解压缩字典!):

>>> [1, 2, *[3, 4], *[5], *(6, 7)]
[1, 2, 3, 4, 5, 6, 7]
>>> (1, *[2, 3], *{"a": 1})
(1, 2, 3, 'a')
>>> {"a": 1, **{"b": 2, "c": 3}, **{"c": "new 3", "d": 4}}
{'a': 1, 'b': 2, 'c': 'new 3', 'd': 4}
当然,最常见的用法是参数解包:

positional_arguments = [12, "a string", (1, 2, 3), other_object]
keyword_arguments = {"hostname": "localhost", "port": 8080}
send(*positional_arguments, **keyword_arguments)
这将转化为:

send(12, "a string", (1, 2, 3), other_object, hostname="localhost", port=8080)
此主题已在另一个 Stack Overflow 问题中大量讨论。

要回复问题请先登录注册