6.8 包的使用
包就是一个包含有init.py文件的文件夹,所以其实我们创建包的目的就是为了用文件夹将文件/模块组织起来
强调:
- 在python3中,即使包下没有
.py文件,import 包仍然不会报错,而在python2中,包下一定要有该文件,否则import 包报错__init__
- 包以及包所包含的模块都是用来被导入的,而不是被直接执行的,而环境变量都是以执行文件为准的。包只是模块的一种形式而已,包的本质就是一种模块
- 导入时遵循原则:凡是在导入时带点的,点的左边都必须是一个包,否则非法。可以带有一连串的点,如item.subitem.subsubitem, 在 . 的右边无要求
- import导入文件时,产生名称空间中的名字来源于文件,import 包,产生的名称空间的名字同样来源于文件,即包下的
.py,导入包本质就是在导入该文件__init__
- 包A和包B下有同名模块也不会冲突,如A.a与B.a来自俩个命名空间
- from .... import...,import后必须是一个明确的名字,没有任何的前缀,from a.b.c.d import g
- 绝对导入与相对导入
绝对导入: 以执行文件的sys.path为起始点开始导入,称之为绝对导入 优点: 执行文件与被导入的模块中都可以使用 缺点: 所有导入都是以sys.path为起始点,导入麻烦 相对导入: 参照当前所在文件的文件夹为起始开始查找,称之为相对导入 符号: .代表当前所在文件的文件加,..代表上一级文件夹,...代表上一级的上一级文件夹 优点: 导入更加简单 缺点: 只能在导入包中的模块时才能使用 注意: 相对导入只能用于包内部模块之间的相互导入,导入者与被导入者都必须存在于一个包内
6.81 导入包的方式
‘包的使用’ #‘包的使用’是最大的文件夹
aaa
bbb
__init__.py #bbb的__init__.py
__init__.py #aaa的__init__.py
m1.py
ccc
__init__.py #ccc的__init__.py
m2.py
包的使用.py #执行文件
包的使用.py
import aaa
print(aaa.x) # aaa.x 就是问__init__.py要一个名字x ,
# 结果 x=1
aaa.m1.f1() # aaa.m1 就是问aaa.__init__.py要一个名字m1
# 结果 这是m1.f1
print(aaa.bbb.zzz) # 就是问bbb的__init__.py要一个名字zzz 结果11111
from aaa import * #此处是想从包aaa导入所有,实际上该语句只会导入包aaa下__init__.py文件中定义的名字,我们可以在这个文件中定义__all___=[\'m1\',\'bbb\'] 表示 * 能导入的方法,不写则表示能导入所有
aaa.
__init__
.py
x=1
from aaa import m1
from aaa import bbb
__all___=[\'m1\',\'bbb\']
aaa.m1.py
def f1():
print(\'这是m1.f1\')
bbb.
__int__
.py
zzz=\'11111\'
总结:如果想调用到同一文件夹下包内的 .py模块
第一步在执行文件下导入包
第二步需要找到包下的
__init__
.py文件,在此文件下导入路径
第三步,调用包下的包,依次类推
6.82 绝对导入和相对导入
绝对导入: 以执行文件的sys.path为起始点开始导入,称之为绝对导入
优点: 执行文件与被导入的模块中都可以使用
缺点: 所有导入都是以sys.path为起始点,导入麻烦
相对导入: 参照当前所在文件的文件夹为起始开始查找,称之为相对导入
符号: . 代表当前所在文件的文件加, ..代表上一级文件夹,...代表上一级的上一级文件夹
优点: 导入更加简单
缺点: 只能在导入包中的模块时才能使用
注意:
1. 相对导入只能用于包内部模块之间的相互导入,导入者与被导入者都必须存在于一个包内
2. attempted relative import beyond top-level package
试图在顶级包之外使用相对导入是错误的,言外之意,必须在顶级包内使用相对导入,每增加一个.代表跳到上一级文件夹,而上一级不应该超出顶级包
例如:在\'包的使用 \' /aaa/m1.py中想要导入\' 包的使用 \' /ccc/m2.py ,不能使用相对导入