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语句语法
格式一:
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)。参见下图:
引入了包以后,只要顶层的包名不冲突,同名的模块就不冲突,如上图中两个AA.py模块不会冲突。注意,每一个包目录下面都会有一个__init__.py的文件(init前后有两个下划线),这个文件是必须存在的,否则,Python就把这个目录当成普通目录,而不是一个包。__init__.py可以是空文件,也可以有代码。当导入包时,python会自动执行 "__init__.py" 里的代码,可作包和模块的初始化。
自己创建模块时要注意命名,不能和Python自带的模块名称冲突。例如,系统自带了sys模块,自己的模块就不可命名为sys.py,否则将无法导入系统自带的sys模块。
简单而言,模块(module)是指py文件,包(package)是指目录(含有__init__.py文件的目录)。i