Python 语法中有一些元素不太常见,也很少用到。这是因为它们能提供的好处很少, 或者它们的用法很难记住。因此,许多 Python 程序员(即使有多年的经验)完全不知道这 些语法元素的存在。其中最有名的例子如下:

• for...else语句。

• 函数注解(functionannotation)。

2.3.1 for...else...语句

在 for 循环之后使用 else 子句,可以在循环“自然”结束而不是被 break 语句终

止时执行一个代码块:

   >>> for number in range(1):

   ...     break

   ... else:

   ...     print("no break")

   ...

   >>>

   >>> for number in range(1):

   ...     pass

   ... else:

   ...     print("break")

   ...

   break

这一语句在某些情况下很有用,因为它有助于删除一些“哨兵(sentinel)”变量,如果 出现 break 时用户想要保存信息,可能会需要这些变量。这使得代码更加清晰,但可能会 使不熟悉这种语法的程序员感到困惑。有人说 else 子句的这种含义是违反直觉的,但这 里介绍一个简单的技巧,可以帮你记住它的用法:for 循环之后 else 子句的含义是“没 有 break”。

2.3.2 函数注解

函数注解是 Python 3 最独特的功能之一。官方文档是这么说的:函数注解是关于用户 自定义函数使用的类型的完全可选的元信息,但事实上,它并不局限于类型提示,而且在 Python 及其标准库中也没有单个功能可以利用这种注解。这就是这个功能独特的原因:它 没有任何语法上的意义。可以为函数定义注解,并在运行时获取这些注解,但仅此而已。 如何使用注解留给开发人员去思考。

1.一般语法

对 Python 官方文档中的示例稍作修改,就可以很好展示如何定义并获取函数注解:

>>> def f(ham: str, eggs: str = 'eggs') -> str: ... pass

...

>>> print(f.__annotations__)

   {'return': <class 'str'>, 'eggs': <class 'str'>, 'ham': <class 'str'>}

如上所述,参数注解的定义为冒号后计算注解值的表达式。返回值注解的定义为表示 def 语句结尾的冒号与参数列表之后的->之间的表达式。

定义好之后,注解可以通过函数对象的__annotations__属性获取,它是一个字典, 在应用运行期间可以获取。

 任何表达式都可以用作注解,其位置靠近默认参数,这样可以创建一些迷惑人的函数

定义,如下所示:

2.3 你可能还不知道的其他语法元素 59

    >>> def square(number: 0<=3 and 1=0) -> (\

   ...     +9000): return number**2

   >>> square(10)

   100

 不过,注解的这种用法只会让人糊涂,没有任何其他作用。即使不用注解,编写出难

以阅读和理解的代码也是相对容易的。