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结果如下图:

 

Python定义模块 python自定义模块并调用_Python

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

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

 

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

 

Python定义模块 python自定义模块并调用_Python_02

import语句语法

格式一:

import 模块名 [as 别名]

说明:1)将整个模块导入。2)[as 别名]部分可无,取别名简化引用。 3)使用导入模块中的成员的格式:模块名[或别名]. 成员

成员包括属性(变量)或函数。

格式二:

from 模块名 import成员名或*

说明:1)导入模块中的某个成员,*代表所有成员。

 

若导入包中模块,将上面语法中的模块名改为 包名.模块名

 

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

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

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

 

如果不同的人编写的模块名相同怎么办?

为了避免模块名冲突,Python又引入了按目录来组织模块的方法,称为包(Package)。参见下图:

Python定义模块 python自定义模块并调用_自定义_03

 

引入了包以后,只要顶层的包名不冲突,同名的模块就不冲突,如上图中两个AA.py模块不会冲突。注意,每一个包目录下面都会有一个__init__.py的文件(init前后有两个下划线),这个文件是必须存在的,否则,Python就把这个目录当成普通目录,而不是一个包。__init__.py可以是空文件,也可以有代码。当导入包时,python会自动执行 "__init__.py" 里的代码,可作包和模块的初始化。

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

简单而言,模块(module)是指py文件,包(package)是指目录(含有__init__.py文件的目录)。i