包就是一个包含有init.py文件的文件夹,因此其实咱们建立包的目的就是为了用文件夹将文件/模块组织起来python
强调:ui
在python3中,即便包下没有__init__
.py文件,import 包仍然不会报错,而在python2中,包下必定要有该文件,不然import 包报错spa
包以及包所包含的模块都是用来被导入的,而不是被直接执行的,而环境变量都是以执行文件为准的。包只是模块的一种形式而已,包的本质就是一种模块code
导入时遵循原则:凡是在导入时带点的,点的左边都必须是一个包,不然非法。能够带有一连串的点,如item.subitem.subsubitem, 在 . 的右边无要求string
import导入文件时,产生名称空间中的名字来源于文件,import 包,产生的名称空间的名字一样来源于文件,即包下的__init__
.py,导入包本质就是在导入该文件it
包A和包B下有同名模块也不会冲突,如A.a与B.a来自俩个命名空间class
from .... import...,import后必须是一个明确的名字,没有任何的前缀,from a.b.c.d import g import
绝对导入与相对导入变量
绝对导入: 以执行文件的sys.path为起始点开始导入,称之为绝对导入 优势: 执行文件与被导入的模块中均可以使用 缺点: 全部导入都是以sys.path为起始点,导入麻烦 相对导入: 参照当前所在文件的文件夹为起始开始查找,称之为相对导入 符号: .表明当前所在文件的文件加,..表明上一级文件夹,...表明上一级的上一级文件夹 优势: 导入更加简单 缺点: 只能在导入包中的模块时才能使用 注意: 相对导入只能用于包内部模块之间的相互导入,导入者与被导入者都必须存在于一个包内
‘包的使用’ #‘包的使用’是最大的文件夹
aaa
bbb
__init__.py #bbb的__init__.py
__init__.py #aaa的__init__.py
m1.py
ccc
__init__.py #ccc的__init__.py
m2.py
包的使用.py #执行文件
包的使用.pymock
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文件,在此文件下导入路径
第三步,调用包下的包,依次类推
绝对导入: 以执行文件的sys.path为起始点开始导入,称之为绝对导入
优势: 执行文件与被导入的模块中均可以使用
缺点: 全部导入都是以sys.path为起始点,导入麻烦
相对导入: 参照当前所在文件的文件夹为起始开始查找,称之为相对导入
符号: . 表明当前所在文件的文件加, ..表明上一级文件夹,...表明上一级的上一级文件夹
优势: 导入更加简单
缺点: 只能在导入包中的模块时才能使用
注意:
1. 相对导入只能用于包内部模块之间的相互导入,导入者与被导入者都必须存在于一个包内
2. attempted relative import beyond top-level package
试图在顶级包以外使用相对导入是错误的,言外之意,必须在顶级包内使用相对导入,每增长一个.表明跳到上一级文件夹,而上一级不该该超出顶级包
例如:在'包的使用 ' /aaa/m1.py中想要导入' 包的使用 ' /ccc/m2.py ,不能使用相对导入