您好,登錄后才能下訂單哦!
小編這次要給大家分享的是詳解Python循環加載模塊,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
循環加載模塊
假設你有兩個文件,a.py和b.py,在這兩個文件中互相加載對方,例如:
在a.py中:
import b def f(): return b.x print f()
在b.py中:
import a x = 1 def g(): print a.f()
首先,我們試著加載a.py:
>>> import a 1
沒有問題。也許讓人吃驚,畢竟有個感覺應該是問題的循環加載在這兒。
事實上在Python中僅僅是表面上的出現循環加載并不是什么問題。如果一個模塊以及被加載了,Python不會傻到再去重新加載一遍。但是,當每個模塊都想要互相訪問定義在對方里的函數或者變量時,問題就來了。
讓我們再回到之前的例子,當我們加載a.py時,它再加載b.py不會有問題,因為在加載b.py時,它并不需要訪問a.py的任何東西,而在b.py中唯一的引用就是調用a.f()。但是這個調用是在函數g()中完成的,并且a.py或者b.py中沒有人調用g(),所以這會兒心情還是美麗的。
但是當我們試圖加載b.py時(之前沒有加載a.py),會發生什么呢:
>>> import b Traceback (most recent call last): File "<stdin>", line 1, in <module> File "b.py", line 1, in <module> import a File "a.py", line 6, in <module> print f() File "a.py", line 4, in f return b.x AttributeError: 'module' object has no attribute 'x'
恭喜你,出錯了。這里問題出在加載b.py的過程中,Python試圖加載a.py,并且在a.py中需要調用到f(),而函數f()又要訪問到b.x,但是這個時候b.x卻還沒有被定義。這就產生了AttributeError異常。
解決的方案可以做一點細微的改動。改一下b.py,使得它在g()里面加載a.py:
x = 1 def g(): import a # 只有當g()被調用的時候才加載 print a.f()
這會兒當我們加載b.py的時候,一切安好:
>>> import b >>> b.g() 1 # 第一次輸出,因為模塊a在最后調用了‘print f()' 1 # 第二次輸出,這是我們調用g()
知識點擴充:
1、使用系統函數__import_()
stringmodule = __import__('string')
2、使用imp 模塊
import imp stringmodule = imp.load_module('string',*imp.find_module('string'))
3、使用exec
import_string = "import string as stringmodule" exec import_string
看完這篇關于詳解Python循環加載模塊的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。