PyTips 0x15 - Python `__future__` 模块

项目地址:https://git.io/pytipspython

咱们常常从一些组织良好的 Python 项目中看到 __future__ 的身影,例如:git

from __future__ import absolute_import, division

__future__ 模块由 PEP 236 提出并加入到 Python 2.1,其存在的主要缘由是 Python 的版本升级常常会增长一些新的特性,而 __future__ 模块将一些新版本中将会增长的新的特性进行声明,同时使得旧版本可使用这些新的语法特性。固然,若是你用的是 Python 2.1 之前的版本,是没办法使用 __future__ 的。__future__ 模块的导入必定要放在最上方,也就是在全部其它模块以前导入。segmentfault

根据 Python 3.5 中 __future__源文件,一共包括下面几个新特性:函数

__future__

表中第一列包含了全部能够从 __future__ 中导入的特性,optional in 中的版本号为最低可以使用的版本mandatory in 中的版本号为已经实现,无需从 __future__ 导入 的版本号。最后一列是每一个新特性所对应的 PEP 及简单描述。下面主要看一下几个 3.0 以后添加的属性。spa

divisioncode

在 3.0 以前,除号 / 的用法都是整除,例如在 2.7 中,8/7=1,若是须要浮点数相除,须要显式使用浮点数类型:8./7=1.1428571428571428,若是是使用变量相除,则须要 a*1.0/7。而在 3.0 之后的版本,整除和浮点数相除分别使用 /// 符号:cdn

from __future__ import division
print(8//7)
print(8/7)
1
1.1428571428571428

absolute_importtoken

PEP 328 主要添加了多行导入和绝对/相对导入的特性,可使用括号而不是 \ 来进行多行导入。相对导入则可使用 . 为标记导入相对目录中的模块,具体能够参考这篇文章:Python导入模块的几种姿式ip

from __future__ import absolute_import

from tkinter import (Tk, Frame, Button, Entry, Canvas, Text,
    LEFT, DISABLED, NORMAL, RIDGE, END)

print_functionget

咱们都知道 3.0 之后 print 变为函数而再也不是声明语句,而是一个内置函数,而且能够接受除打印内容之外的参数:

print(*args, sep=' ', end='\n', file=None)

from __future__ import print_function
print("Hello", "World", sep=',', end='!')
Hello,World!

generator_stop

在生成器内部使用 raise StopIteration 意味着生成器终止,但这样写会形成一些隐藏的 BUG(见 PEP 479),新的特性要求杜绝这一用法并抛出 RuntimeError,若要终止生成器,请使用 return

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)
0
1
generator raised StopIteration

彩蛋

为了吸引更多 Java、C 等语言的用户,使他们更快适应 Python 代码缩进的语法同时又能兼容他们不可抑制地输入 {} 的冲动,__future__ 还提供了 braces 特性,使花括号能够被正确解析!

from __future__ import braces

欢迎关注公众号 PyHub 每日推送

pyhub

相关文章
相关标签/搜索