作者:闻菲,肖琴
【新智元导读】Python官网静悄悄地发布了一条大消息:正式发布 Python 3.7.0!同时发布的还有Python 3.6.6稳定版。官网刚刚更新了可下载文档,还在用Python 2.7和Python3.5的你,赶紧用起来!
下载地址:https://www.python.org/downloads/
Python官网宣布,正式发布Python 3.7.0!
2018年6月27日星期三
Python 3.7.0现已推出(同时还有3.6.6版本)!
代表Python开发社区和Python 3.7发布团队,我们很高兴地宣布Python 3.7.0现在可以使用了。Python 3.7.0是Python语言的最新功能版本,包含许多新的功能和优化。你可以在这里下载 Python 3.7.0:
https://www.python.org/downloads/release/python-370/
Python的大多数第三方库也应该尽快支持3.7.0软件包。
有关3.7系列功能的更多信息,请参阅Python 3.7中的新功能文档。有关3.7.0中所做更改的详细信息,请参见其更改日志。3.7系列的维护版本将从2018年7月开始定期进行。
我们希望您喜欢Python 3.7!
另附:我们也很高兴地宣布,Python 3.6.6的下一个维护版本Python 3.6可以使用了:https://www.python.org/downloads/release/python-366/
感谢所有帮助Python开发和这些发布的志愿者!欢迎通过志愿或组织捐赠支持Python软件基金会的工作。
Python 3.7.0 重大功能改进
那么,这次新发布的Python 3.7.0 有哪些重要的改进呢?总的来说,
新的syntax功能:
PEP 563,推迟了类型注释(type annotations)的评估
向后不兼容的syntax更改:
async 和 await 现在是保留关键词
新的库模块:
contextvars:PEP 567 - 上下文变量
dataclasse:PEP 557 - 数据类
importlib.resources
新的内置功能:
PEP 553,新的 breakpoint() 函数
Python 数据模型改进:
PEP 562,定制访问模块属性
PEP 560,核心支持 typing module 和 generic types
dict 对象的插入顺序保存性质被纳入Python官方语言规范
标准库的重大改进:
asyncio 模块增加了新功能,提高了可用性和性能
time 模块新增纳秒级函数支持,新函数将纳秒数作为整数值返回
CPython 部署改进:
避免使用 ASCII 作为默认文本编码
PEP 552,deterministic .pycs
新的 runtime 模式
PEP 565,改进了 DeprecationWarning 处理
C API 改进:
PEP 539,用于线程本地存储的新C API
文档改进:
PEP 545,Python文档翻译
新增日语、法语和韩语文档
Python 3.7.0 新增特性
那么,接下来详细看看这些功能。
PEP 563:推迟对注释语句的评估
Python的类型提示有两个明显的可用性问题:
注释只能使用当前范围内已有的名称,换句话说,它们不支持任何类型的前向引用; 注释源代码对Python程序的启动时间有不利影响。
通过推迟注释评估可以解决这两个问题。编译器不是编译在定义时在注释中执行表达式的代码,而是将注释以字符串形式存储。如果需要,可以使用typing.get_type_hints()在运行时解析注释。在不需要解析的常见情况下,注释的存储成本更低,并且启动时间更快。
PEP 538:C语言环境强制
Python 3系列中的一个持续的挑战是确定一种合理的默认策略,用于处理目前在非Windows平台上使用默认C或POSIX语言环境的“7-bit ASCII”文本编码假设。
PEP 538更新默认解释器命令行界面,自动将该语言环境强制转换为可用的基于UTF-8的语言环境。 自动设置LC_CTYPE意味着核心解释器和C扩展(例如readline)将假设使用UTF-8作为默认文本编码,而不是ASCII。
PEP 540:强制UTF-8 Runtime 模式
新的-X utf8命令行选项和PYTHONUTF8环境变量可用于启用CPython UTF-8模式。
PEP 553:内置breakpoint()
Python 3.7新增了内置函数breakpoint(),作为进入Python调试器的简单而一致的方式。
PEP 539:新增用于线程本地存储的C API
虽然Python为线程本地存储支持提供了一个C API; 但现有的线程本地存储(TLS)API使用int来表示所有平台上的TLS密钥,但这既不符合POSIX标准,也不具备任何实际意义上的便携性。
PEP 539通过向CPython提供新的线程本地存储(TSS)API来改变这一点,该API取代了在CPython解释器中使用现有TLS API,同时弃用现有API。TSS API使用新类型Py_tss_t而不是int来表示TSS密钥,这将允许在本地TLS密钥定义的平台上构建CPython。
PEP 562:定制对模块属性的访问
Python 3.7支持在模块上定义__getattr __(),并且只要没有找到模块属性就会调用它。也允许在模块上定义__dir __()。
PEP 564:time 内置函数支持纳秒
为了避免精度损失,PEP 564在timemodule添加了六个新“纳秒”(nanosecond)变量:
time.clock_gettime_ns()
time.clock_settime_ns()
time.monotonic_ns()
time.perf_counter_ns()
time.process_time_ns()
time.time_ns()
PEP 565:在__main__中默认显示DeprecationWarning
DeprecationWarning的默认处理已更改,以便默认情况下再次显示这些警告,但仅当触发它们的代码直接在__main__模块中运行时才会显示。
PEP 560:新增支持类型模块和泛型
PEP引入了两种特殊方法__class_getitem __()和__mro_entries__,这些方法现在被大多数类和特殊构造用于输入。结果,不同类型的各种操作的速度提高了7倍,可以使用泛型而没有元类冲突,并且修改了类型模块中长期存在的一些bug。
PEP 552:基于哈希的.pyc文件
PEP 552扩展了pyc格式,允许源文件的哈希值用于invalidation,而不是源timestamp。这种.pyc文件称为“hash-based”。默认情况下,Python仍然使用基于时间戳的invalidation,并且不会在运行时生成基于哈希的.pyc文件。可以使用py_compile或compileall生成基于哈希的.pyc文件。
PEP 545:Python文档翻译
PEP 545描述了创建和维护Python文档翻译的过程。添加了三种语言的翻译:
•日本:https://docs.python.org/ja/
•法语:https://docs.python.org/fr/
•韩国:https://docs.python.org/ko/
开发运行时模式:-X dev
新的-X dev命令行选项或newPYTHONDEVMODE环境变量可用于启用CPython的开发模式。在开发模式下,CPython执行额外的运行时检查,这些检查无法在默认情况下启用。
性能提升及文档下载
根据官方文档表示,新升级的各种优化使 Linux 上的 Python 启动时间减少了 10%,而 macOS 上的启动时间更是减少了 30%。
由于字节码更改,方法调用现在可以快 20%。
由于PEP 560工作,typing 导入时间减少了 7 倍,现在许多 typing 操作也更快。
等等优化,还有更多。
Python官网有非常全面的文档,是今天刚刚更新的:
也列出了转换为新版本会遇到的问题和应对方法:
现在,Python 3.7.0 已经可以下载:https://www.python.org/downloads/
还等什么,赶快用起来!