In [1]:
from __future__ import absolute_import, division
表中第一列包含了所有可以从 __future__ 中导入的特性,optional in 中的版本号为最低可使用的版本,mandatory in 中的版本号为已经实现,无需从 __future__ 导入 的版本号。最后一列是每个新特性所对应的 PEP 及简单描述。下面主要看一下几个 3.0 之后添加的属性。
division
在 3.0 之前,除号 / 的用法都是整除,例如在 2.7 中,8/7=1,如果需要浮点数相除,需要显式使用浮点数类型:8./7=1.1428571428571428,如果是使用变量相除,则需要 a*1.0/7。而在 3.0 以后的版本,整除和浮点数相除分别使用 // 和 / 符号:
In [2]:
from __future__ import division
print(8//7)
print(8/7)
absolute_import
PEP 328 主要添加了多行导入和绝对/相对导入的特性,可以使用括号而不是 \ 来进行多行导入。相对导入则可以使用 . 为标记导入相对目录中的模块,具体可以参考这篇文章:Python导入模块的几种姿势。
In [3]:
from __future__ import absolute_import
from tkinter import (Tk, Frame, Button, Entry, Canvas, Text,
LEFT, DISABLED, NORMAL, RIDGE, END)
print_function
我们都知道 3.0 以后 print 变为函数而不再是声明语句,而是一个内置函数,并且可以接受除打印内容以外的参数:
print(*args, sep=' ', end='\n', file=None)
In [4]:
from __future__ import print_function
print("Hello", "World", sep=',', end='!')
generator_stop
在生成器内部使用 raise StopIteration 意味着生成器终止,但这样写会造成一些隐藏的 BUG(见 PEP 479),新的特性要求杜绝这一用法并抛出 RuntimeError,若要终止生成器,请使用 return。
In [5]:
from __future__ import generator_stop
def gen(n):
i = 0
while i < n:
yield i
i += 1
if i % 2 == 0:
raise StopIteration
# use return
g = gen(3)
print(next(g))
print(next(g))
try:
print(next(g))
except RuntimeError as err:
print(err)