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模块。