返回介绍

模拟 Python 3.0 print 函数

发布于 2024-01-29 22:24:16 字数 2923 浏览 0 评论 0 收藏 0

为了圆满结束本章,让我们来看参数匹配用法的最后一个例子。这里看到的代码专门用于Python 2.6或更早的版本(它在Python 3.0下也能工作,但是没有什么意义):它使用*args任意位置元组以及**args任意关键字参数字典来模拟Python 3.0 print函数所做的大多数工作。

正如我们在第11章所了解到的,这实际上不是必需的,因为Python 2.6程序员总是可以通过如下形式的一个导入来使用Python 3.0的print函数:

然而,为了说明一般性的参数匹配,如下的文件print30.py,用少量可重用的代码做了同样的工作:

为了测试它,将其导入到另一个文件或交互提示模式中,并且像Python 3.0 print函数那样使用它。这里是一个测试脚本testprint30.py(注意,该函数必须叫做"print30",因为"print"在Python 2.6中是保留字):

在Python 2.6下运行的时候,我们得到了与Python 3.0的print函数相同的结果:

尽管在Python 3.0中没有意义,但运行的时候,结果是相同的。与通常情况一样,Python的通用性设计允许我们在Python语言自身中原型化或开发概念。在这个例子中,参数匹配工具在Python代码中与在Python的内部实现中一样的灵活。

使用Keyword-Only参数

这个例子可以使用本章前面所介绍的Python 3.0 keyword-only参数来编写,从而来自动验证配置参数,注意到这一点是很有趣的:

这个版本与最初的版本一样有效,并且它是说明keyword-only参数如何方便好用的基本例子。最初的版本假设所有的位置参数都要打印,并且所有的keyword-only参数都只是可选的。大多数情况下这样就够了,但是,任何额外的keyword-only参数都默默地忽略掉了。例如,如下的一个调用将会对keyword-only参数形式产生一个异常:

但是,会默默地忽略最初版本中的name参数。要手动检测多余的关键字,我们可以使用dict.pop()删除收到的条目,并检查字典是否为空。这里是keyword-only参数版本的一个对等形式:

它和前面一样有效,但是,现在,它也会捕获外部的关键字参数:

这个版本的函数在Python 2.6下运行,但是,它比keyword-only参数版本需要额外的4行代码。遗憾的是,这个例子中需要额外的代码,keyword-only参数版本只在Python 3.0下工作,这否定了我编写这个例子的首要原因(一个Python 3.0的模拟程序,只能在Python 3.0下工作,其用途是令人难以置信的)。在编写来运行于Python 3.0的程序中,keyword-only参数可以简化一类既接受参数又接受选项的函数。在后面的第20章的迭代计时案例学习中,有Python 3.0的keyword-only参数的另一个示例。

为什么要在意:关键字参数

你可能已经知道了,高级参数匹配模式可能更复杂。它们也完全是可选的,你可以只使用简单的位置匹配,并且,当你刚开始编程的时候,这可能是一个好办法。然而,由于一些Python工具使用它们,了解一些关于这些模式的常识是很重要的。

例如,关键字参数在tkinter中扮演很重要的角色,Tkinter是Python中的标准GUI API(该模块在Python 2.6中的名称是Tkinter)。我们在本书的多个地方简单地介绍过tkinter,但只是介绍了当构建GUI组件的时候的调用模式、关键字参数设置配置选项。例如,一种调用形式:

创建了一个新的按钮并定义了它的文字以及回调函数,使用了text和command关键字参数。因为对于一个部件的设置选项的数目可能很多,关键字参数能够从中进行选择。如果不是这样的话,也许必须根据位置列举出所有可能的选项,要么期待一个明智的基于位置的参数的默认协议来处理每一个可能选项的设置。

Python中的很多内置函数期待我们对使用模式的选项也用关键字参数,这可能有默认值也可能没有。例如,我们在第8章所学习过的sorted内置函数:

期待我们传入一个可迭代对象来进行排序,但是,也允许我们传递可选的关键字参数来指定一个字典排序键和一个反向排序标志,其默认值分别为None和False。因为我们通常不会使用这些选项,它们可能会被省略而使用默认值。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文