python 之 包的使用
6.8 包的使用
包就是一个包含有init.py文件的文件夹,所以其实我们创建包的目的就是为了用文件夹将文件/模块组织起来
强调:
-
在python3中,即使包下没有
__init__
.py文件,import 包仍然不会报错,而在python2中,包下一定要有该文件,否则import 包报错 -
包以及包所包含的模块都是用来被导入的,而不是被直接执行的,而环境变量都是以执行文件为准的。包只是模块的一种形式而已,包的本质就是一种模块
-
导入时遵循原则:凡是在导入时带点的,点的左边都必须是一个包,否则非法。可以带有一连串的点,如item.subitem.subsubitem, 在 . 的右边无要求
-
import导入文件时,产生名称空间中的名字来源于文件,import 包,产生的名称空间的名字同样来源于文件,即包下的
__init__
.py,导入包本质就是在导入该文件 -
包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 ,不能使用相对导入