返回介绍

以两种方式使用代码

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

尽管文件底部的测试代码是有用的,但是有一个大问题,当文件作为脚本运行的时候,或者当它作为一个模块导入的时候,它的顶层的print语句都会运行。这意味着,如果我们确定要在这个文件中导入该类以便在其他某个地方使用它(我们在本章稍后将要用到它),那么每次导入文件的时候,我们都会看到其测试代码的输出。这不是一种很好的软件关系,因为,客户端程序可能不关心我们内部的测试,也不希望看到我们的输出和它们自己的输出混合到一起。

尽管我们可以把测试代码分隔到一个单独的文件中,在与被测试的项目相同的一个文件中编写测试代码往往更加方便。但是,只有当文件为了测试而运行,而不是导入文件的时候,在文件底部运行测试语句才会比较好安排。__name__检查模块的设计意图正是如此,这一点我们在前面已经介绍过。这需要进行如下的添加:

现在,我们得到了确实想要的操作:把文件作为顶层脚本运行的时候,测试它,因为其__name__是__main__,但随后将它作为类库导入的时候,则不会这么做:

导入的时候,文件现在定义了类,但是,没有使用它。当直接运行的时候,文件像前面一样创建了类的两个实例,并且打印出每个实例的两个属性。再次说明,由于每个实例都是一个独立的命名空间对象,它们的属性的值不同。

版本差异提示

我在Python 3.0下运行本章的所有代码,并且使用Python 3.0的print函数调用语法。如果你在Python 2.6下运行代码,代码也能正常工作,但是注意用圆括号括住一些输入行,因为打印语句中额外的圆括号把多个项目纳入一个元组:

如果这种差别太过详细,让你感到不适,直接去除掉圆括号以使用Python 2.6的print语句。可以使用格式化以产生一个单个的对象来打印,从而避免额外的圆括号。如下的两种形式在Python 2.6和Python 3.0中都有效,尽管使用方法的形式比较新。

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

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

发布评论

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