Python自定义模块

一时失言乱红尘 2023-10-07 23:40 47阅读 0赞

37411df53acea6d5f80866b598b38156.png

到目前为止,读者已经掌握了导入 Python 标准库并使用其成员(主要是函数)的方法,接下来要解决的问题是,怎样自定义一个模块呢?

Python 模块就是 Python 程序,换句话说,只要是 Python 程序,都可以作为模块导入。例如,下面定义了一个简单的模块(编写在 demo.py 文件中):

  1. name ="Python教程"
  2. add ="http://csdn.net/python"
  3. print(name,add)
  4. defsay():
  5. print("人生苦短,我学Python!")
  6. class CLanguage:
  7. def__init__(self,name,add):
  8. self.name = name
  9. self.add = add
  10. defsay(self):
  11. print(self.name,self.add)

可以看到,我们在 demo.py 文件中放置了变量(name 和 add)、函数( say() )以及一个 Clanguage 类,该文件就可以作为一个模板。

但通常情况下,为了检验模板中代码的正确性,我们往往需要为其设计一段测试代码,例如:

  1. say()
  2. clangs =CLanguage("csdn社区","http://csdn.net.net")
  3. clangs.say()

运行 demo.py 文件,其执行结果为:

Python教程 http://csdn.net/python
人生苦短,我学Python!
csdn社区 http://csdn.net.net

通过观察模板中程序的执行结果可以断定,模板文件中包含的函数以及类,是可以正常工作的。

在此基础上,我们可以新建一个 test.py 文件,并在该文件中使用 demo.py 模板文件,即使用 import 语句导入 demo.py:

  1. import demo

注意,虽然 demo 模板文件的全称为 demo.py,但在使用 import 语句导入时,只需要使用该模板文件的名称即可。

此时,如果直接运行 test.py 文件,其执行结果为:

Python教程 http://csdn.net/python
人生苦短,我学Python!
csdn社区 http://csdn.net.net

可以看到,当执行 test.py 文件时,它同样会执行 demo.py 中用来测试的程序,这显然不是我们想要的效果。正常的效果应该是,只有直接运行模板文件时,测试代码才会被执行;反之,如果是其它程序以引入的方式执行模板文件,则测试代码不应该被执行。

要实现这个效果,可以借助 Python 内置的 __name__ 变量。当直接运行一个模块时,name 变量的值为 __main__;而将模块被导入其他程序中并运行该程序时,处于模块中的 __name__ 变量的值就变成了模块名。因此,如果希望测试函数只有在直接运行模块文件时才执行,则可在调用测试函数时增加判断,即只有当 __name__ ==’__main__‘ 时才调用测试函数。

因此,我们可以修改 demo.py 模板文件中的测试代码为:

  1. if __name__ =='__main__':
  2. say()
  3. clangs =CLanguage("csdn社区","http://csdn.net")
  4. clangs.say()

这样,当我们直接运行 demo.py 模板文件时,其执行结果不变;而运行 test.py 文件时,其执行结果为:

Python教程 http://csdn.net/python

显然,这里执行的仅是模板文件中的输出语句,测试代码并未执行。

自定义模块编写说明文档

我们知道,在定义函数或者类时,可以为其添加说明文档,以方便用户清楚的知道该函数或者类的功能。自定义模块也不例外。

为自定义模块添加说明文档,和函数或类的添加方法相同,即只需在模块开头的位置定义一个字符串即可。例如,为 demo.py 模板文件添加一个说明文档:

‘’’
demo 模块中包含以下内容:
name 字符串变量:初始值为“Python教程”
add 字符串变量:初始值为“ http://csdn.net/python ”
say() 函数
CLanguage类:包含 name 和 add 属性和 say() 方法。
‘’’

在此基础上,我们可以通过模板的 __doc__ 属性,来访问模板的说明文档。例如,在 test.py 文件中添加如下代码:

import demo
print(demo.__doc__)

程序运行结果为:

Python教程 http://csdn.net/python

demo 模块中包含以下内容:
name 字符串变量:初始值为“Python教程”
add 字符串变量:初始值为“ http://csdn.net/python ”
say() 函数
CLanguage类:包含 name 和 add 属性和 say() 方法。

发表评论

表情:
评论列表 (有 0 条评论,47人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Python教程——导入定义模块

    导入自定义模块之前我们先创建一个自己的模块,功能可以随便写,比如下面所示定义了两个功能模块,一个是输出调用的名字,一个是计算九九乘法表 在项目下创建一个demo包,在包下创建

    相关 定义模块

    自定义模块 Python中有许多模块是系统自带的,也可以自己编写模块,自定义模块。 所谓的自定义模块,就是将写好的python程序(后缀名为.py)放在lib

    相关 定义模块

    1. 模块的定义与分类 模块是什么? 这几天,我们进入模块的学习。在学习模块之前,我们首先要知道,什么是模块? 一个函数封装一个功能,你使用的软件可能就是由n多

    相关 Python_定义模块

    自定义模块例子(web简单框架):   专门处理逻辑的包:处理各种访问需求   数据库的交互:面临各种的查询,删改 ,dba,   配置文件(全局配置文件):列存储数据的