python中的自定义模块及其使用

python中的自定义模块及其使用

python中的自定义模块,就不是python自带的模块,而是通过自己来创建出来的。

在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护。

为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,很多编程语言都采用这种组织代码的方式。在Python中,一个.py文件就称之为一个模块(Module),如一个xyz.py的文件就是一个名字叫xyz的模块。

使用模块的意义

提高了代码的可维护性。其次,编写代码不必从零开始。当一个模块编写完毕,就可以被其他地方引用。还可以避免函数名和变量名冲突。相同名字的函数和变量完全可以分别存在不同的模块中,因此,我们自己在编写模块时,不必考虑名字会与其他模块冲突。

 

python自定义模块及其使用的简单例子

建立名为 myM.py文件,作为自定义模块文件,内容如下:

def add(a, b):

    return a + b

def sub(a, b):

    return a - b

 

建立使用 import myM的名为的testA.py测试文件,内容如下:

import myM

print("add(1, 2)的结果", myM.add(1, 2))

print("sub(2, 3)的结果:", myM.sub(2, 3))

 

将testA.py文件和myM.py文件保存在同一目录(文件夹)中,运行testA.py结果如下图:

 

建立使用from myM import add的名为的testB.py测试文件,内容如下:

from myM import add

print("add(1, 2): 的结果",add(1, 2))

 

将testB.py文件和hello.py文件保存在同一目录(文件夹)中,运行testB.py结果如下图:

 

提示:import xxx和from xxx import yyy,两者的区别在于:

import xxx,需要通过xxx.yyy的方式使用导入模块中的变量、函数、类等。

from xxx import yyy,可以直接以yyy调用。

 

如果不同的人编写的模块名相同怎么办?为了避免模块名冲突,Python又引入了按目录来组织模块的方法,称为包(Package)。

假设我们的abc和xyz这两个模块名字与其他模块冲突了,于是我们可以通过包来组织模块,避免冲突。方法是选择一个顶层包名,比如myPack,按照如下目录存放:

myPack

├─ __init__.py

├─ abc.py

└─ xyz.py

引入了包以后,只要顶层的包名不与别人冲突,那所有模块都不会与别人冲突。现在,abc.py模块的名字就变成了myPack.abc,类似的,xyz.py的模块名变成了myPack.xyz。

 

注意,每一个包目录下面都会有一个__init__.py的文件,这个文件是必须存在的,否则,Python就把这个目录当成普通目录,而不是一个包。__init__.py可以是空文件,也可以有Python代码,因为__init__.py本身就是一个模块,而它的模块名就是myPack。

自己创建模块时要注意命名,不能和Python自带的模块名称冲突。例如,系统自带了sys模块,自己的模块就不可命名为sys.py,否则将无法导入系统自带的sys模块。

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章