包是模块的一种形式,包的本质就是一个含有.py的文件的文件夹。
python
模块的第一个版本只有10个功能,可是将来在扩展版本的时候,模块名和用法应该最好不要去修改,可是这只是对使用者友好,而因为版本扩展,文件愈来愈大,模块设计者对模块的管理、维护会愈来愈复杂,所以咱们可使用包来扩展模块的功能。设计
导入模块发生的三件事:code
1.建立一个包的名称空间
2.执行py文件,将执行过程当中产生的名字存放于名称空间中。
3.在当前执行文件中拿到一个名字aaa,aaa是指向包的名称空间的
导入包发生的三件事:it
1.建立一个包的名称空间
2.因为包是一个文件夹,没法执行包,所以执行包下的.py文件,将执行过程当中产生的名字存放于包名称空间中(即包名称空间中存放的名字都是来自于.py)
3.在当前执行文件中拿到一个名字aaa,aaa是指向包的名称空间的
导入包就是在导入包下的.py,而且可使用如下两种方式导入:class
1.import ...
2.from ... import...import
以下咱们若是须要扩展aaa.py模块,须要创建一个aaa的目录文件,而且删除aaa.py文件,将aaa.py修改为m1.py和m2.py两个文件,让模块的功能使用方法不改变。变量
# aaa.py def func1(): pass def func2(): pass def func3(): pass def func4(): pass def func5(): pass def func6(): pass
# m1.py def func1(): pass def func2(): pass def func3(): pass
# m2.py def func4(): pass def func5(): pass def func6(): pass
# run.py import aaa aaa.func1() aaa.func2() aaa.func3() aaa.func4() aaa.func5() aaa.func6()
# aaa/.py func1 = 111 func2 = 222 func3 = 333 func4 = 444 func5 = 555 func6 = 666
因为在__init__.py中定义了func1,所以咱们能够在run.py文件中导入func1,可是这个func1并非咱们想要的func1,所以须要修改__init__.py文件,又因为执行文件run.py的环境变量不为aaa,所以直接使用import导入m1会报错,所以使用from导入。扩展
# aaa/.py from aaa.m1 import func1 from aaa.m2 import func2
# run.py import aaa print(aaa.func1()) print(aaa.func2())
# bbb/.py from aaa import bbb
# run.py import aaa print(aaa.bbb)
若是bbb包内部有m3.py,咱们须要从run.py导入m3模块。语法
# bbb/.py from aaa.bbb import m3
# run.py import aaa aaa.bbb.m3
绝对导入:方法
# aaa/.py from aaa.m1 import func1 from aaa.m2 import func2
对导入:
* .表明当前被导入文件所在的文件夹
* ..表明当前被导入文件所在的文件夹的上一级
* ...表明当前被导入文件所在的文件夹的上一级的上一级
from .m1 import func1 from .m2 import func2
1.包内全部的文件都是被导入使用的,而不是被直接运行的 2.包内部模块之间的导入可使用绝对导入(以包的根目录为基准)与相对导入(以当前被导入的模块所在的目录为基准),推荐使用相对导入 3.当文件是执行文件时,没法在该文件内用相对导入的语法,只有在文件时被看成模块导入时,该文件内才能使用相对导入的语法 4.凡是在导入时带点的,点的左边都必须是一个包,import aaa.bbb.m3.f3错误