我的代码
$ 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 "<stdin>", line 1
SyntaxError: can't use starred expression here
>>>
我的问题,为什么?
用一种更严肃的语气:我想要一个答案或参考,详细说明使用星号表达的所有细节,因为碰巧我有时会对其行为感到惊讶......
反映一些有启发性的评论 我紧跟我的问题后添加以下代码
>>> '%d %d' % (, *a)
File "<stdin>", line 1
'%d %d' % (, *a)
^
SyntaxError: invalid syntax
>>> '%d %d' % (*a,)
'1 2'
>>>
(我在发布原始问题之前尝试了(, a)
部分,但我省略了它,因为错误与主演无关。)
有一个语法,在python≥3.5,“只是工作”但是我想要一些理解。
答案 0 :(得分:23)
这是因为:
(a)
只是括号括起来的值。它不是一个新的元组对象。所以你的表达:
>>> '%d %d' % (*a)
将被翻译为:
>>> '%d %d' % * a
这在python语法方面显然是错误的。
为了创建一个新的元组,使用一个表达式作为初始值设定项,您需要在其后添加“,
”:
>>> '%d %d' % (*a,)
注意:除非a
是生成器,否则在这种情况下您只需键入:
>>> '%d %d' % a
另外,如果我可以提出一些建议:你可以开始使用新式的格式化表达式。他们很棒!
>>> "{} {}".format(*a)
您可以在python文档的t w o段中阅读有关它们的更多信息,还有this个很棒的网站。上面的行使用下面描述的参数解包机制。
除了创建新的列表/元组/字典之外,还有更多用于加星标表达的用法。其中大多数都在this PEP和this one
中进行了描述所有这些都归结为两种:
RValue拆包:
>>> a, *b, c = range(5)
# a = 0
# b = [1, 2, 3]
# c = 4
>>> 10, *range(2)
(10, 0, 1)
Iterable / dictionary对象初始化(注意你也可以在列表中解压缩字典!):
>>> [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 question中。
答案 1 :(得分:3)
我的问题,为什么?
因为你的python语法不允许这样做。它是这样定义的,所以没有真正的“为什么”。
另外,这是不必要的。
"%d %d" % a
会起作用。
所以,你需要将扩展转换为元组 - 正如Lafexlos所指出的那样,正确的做法是
"%d %d" % (*a,)
答案 2 :(得分:0)
这是因为:
>>> '%d %d' % (*a)
可以是:
>>> '%d %d' %a
当然可以了:
>>> '%d %d' % (*a,)
但是然后:
>>> (*a,)==a
True
>>>
或者您可以这样做:
>>> '%d %d' % [*a]
但是然后:
>>> [*a]
[1, 2]
>>> a
(1, 2)
>>>
所以:
>>> tuple([*a])==a
True