包就是一個包含有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 ,不能使用相對導入