Skip to main content

什么是PEP

什么是PEP

PEP的全称是Python Enhancement Proposals,其中Enhancement是增强改进的意思,Proposals则可译为提案或建议书,所以合起来,比较常见的翻译是Python增强提案Python改进建议书

Python核心开发者主要通过邮件列表讨论问题、提议、计划等,PEP通常是汇总了多方信息,经过了部分核心开发者review和认可,最终形成的正式文档,起到了对外公示的作用,所以我认为翻译成“提案”更恰当。

PEP的官网是:https://peps.python.org/,这也就是PEP 0 的地址。其它PEP的地址是将编号拼接在后面,例如:https://www.python.org/dev/peps/pep-0020/ 就是PEP 20 的链接,以此类推。

第一个PEP诞生于2000年,现在正好是18岁成年。

到目前为止,它拥有478个“兄弟姐妹”。

PEP的分类

官方将PEP分成三类:

  • I - Informational PEP

  • P - Process PEP

  • S - Standards Track PEP

其含义如下:

  • 信息类(Informational):这类PEP就是提供信息,有告知类信息,也有指导类信息等等。例如PEP 20(The Zen of Python,即著名的Python之禅)、PEP 404 (Python 2.8 Un-release Schedule,即宣告不会有Python2.8版本)。
  • 流程类(Process ):这类PEP主要是Python本身之外的周边信息。例如PEP 1(PEP Purpose and Guidelines,即关于PEP的指南)、PEP 347(Migrating the Python CVS to Subversion,即关于迁移Python代码仓)。
  • 标准类(Standards Track):这类PEP主要描述了Python的新功能和新实践(implementation),是数量最多的提案。例如我之前提到过的f-string方式,它出自PEP 498(Literal String Interpolation,字面字符串插值)。

每个PEP最初都是一个草案(Draft),随后会经历一个过程,因此也就出现了不同的状态。以下是一个流程图:

image-20220906210611248

  • A – Accepted (Standards Track only) or Active proposal 已接受(仅限标准跟踪)或有效提案

  • D – Deferred proposal 延期提案

  • F – Final proposal 最终提案

  • P – Provisional proposal 暂定提案

  • R – Rejected proposal 被否决的提案

  • S – Superseded proposal 被取代的提案

  • W – Withdrawn proposal 撤回提案

在PEP 0(Index of Python Enhancement Proposals (PEPs))里,官方列举了所有的PEP,你可以按序号、按类型以及按状态进行检索。而在PEP 1(PEP Purpose and Guidelines)里,官方详细说明了PEP的意图、如何提交PEP、如何修复和更新PEP、以及PEP评审的机制等等。

为什么要读PEP?

无论你是刚入门Python的小白、有一定经验的从业人员,还是资深的黑客,都应该阅读Python增强提案。

依我之见,阅读PEP至少有如下好处:

(1)了解Python有哪些特性,它们与其它语言特性的差异,为什么要设计这些特性,是怎么设计的,怎样更好地运用它们;

(2)跟进社区动态,获知业内的最佳实践方案,调整学习方向,改进工作业务的内容;

(3)参与热点议题讨论,或者提交新的PEP,为Python社区贡献力量。

说到底,学会用Python编程,只是掌握了皮毛。PEP提案是深入了解Python的途径,是真正掌握Python语言的一把钥匙,也是得心应手使用Python的一本指南。

哪些PEP是必读的?

如前所述,PEP提案已经累积产生了478个,我们并不需要对每个PEP都熟知,没有必要。下面,我列举了一些PEP,推荐大家一读:

PEP名称说明
0Index of Python Enhancement Proposals所有PEP的一个目录,索引
4Deprecation of Standard Modules已经弃用的标准模块
7Style Guide for C CodeC扩展
8Style Guide for Python Code编码规范(必读)
20The Zen of PythonPython之禅
202List Comprehensions列表生成式
274Dict Comprehensions字典生成式
234Iterators迭代器
257Docstring Conventions文档注释规范
279The enumerate() built-in functionenumerate枚举
282A Logging System日志模块
285Adding a bool type布尔值(建议阅读《Python对象的身份迷思:从全体公民到万物皆数》)
289Generator Expressions生成器表达式
318Decorators for Functions and Methods装饰器
342Coroutines via Enhanced Generators协程
343The "with" Statementwith语句
380Syntax for Delegating to a Subgeneratoryield from语法
405Python Virtual Environments虚拟环境
471os.scandir() function遍历目录
484Type Hints类型约束
492Coroutines with async and await syntaxasync/await语法
498Literal String Interpolation Python字符串插值
525Asynchronous Generators异步生成器
572Assignment Expressions表达式内赋值(最争议)
3105Make print a functionprint改为函数
3115Metaclasses in Python 3000元类
3120Using UTF-8 as the default source encoding
3333Python Web Server Gateway Interface v1.0.1Web开发
8000Python Language Governance Proposal OverviewGvR老爹推出决策层后

一些翻译了的PEP项目