这种奇怪的结肠行为在做什么?
我正在使用Python 3.6.1,但遇到了一些非常奇怪的事情。我有一个简单的字典作业错字,花了很长时间才找到。
context = {}
context["a"]: 2
print(context)
输出量
{}
代码context["a"]:
2
在做什么?SyntaxError
IMO应该什么时候都没有提出。起初,我认为它正在创建一个切片。但是,键入repr(context["a"]:
2)
会引发一个SyntaxError
。我也输入context["a"]:
2
了控制台,但控制台没有打印任何内容。我以为也许它回来了None
,但是我不太确定。
我还认为这可能是单行if语句,但这也不应该是正确的语法。
此外,context["a"]
应提出一个KeyError
。
我很困惑。到底是怎么回事?
-
您不小心编写了语法正确的 变量注释 。该功能是Python 3.6中引入的(请参阅PEP
526)。尽管将变量注释解析为带注释的赋值的一部分,但是赋值语句是 可选的 :
annotated_assignment_stmt ::= augtarget ":" expression ["=" expression]
因此,在
context["a"]: 2
context["a"]
是注释目标2
是注释本身context["a"]
未初始化
PEP指出 “注释的目标可以至少在语法上是任何有效的单个分配目标(取决于类型检查器的处理方式)”
,这意味着该密钥不需要存在带注释(因此没有KeyError
)。这是原始PEP的示例:d = {} d['a']: int = 0 # Annotates d['a'] with int. d['b']: int # Annotates d['b'] with int.
通常情况下,注释表达式 应该 计算为Python类型-毕竟主要使用注解是类型提示,但不会强制执行。注释可以是任何 有效的
Python表达式,无论结果的类型或值如何。如您所见,此时,除非您有诸如mypy之类的静态类型检查器,否则类型提示非常宽松,很少有用。