from module import *把module中的成員所有導到了當前的global namespace,訪問起來就比較方便了。固然,python style通常不建議這麼作,由於可能引發name conflict。python
但還有另一個問題 - 你覺得你修改了某個變量,其實,被from module import *後的那個並無被更新,很是危險,由於程序有可能還能夠正常運行, 只不過結果錯了,到了production才被發現就比較慘了。git
舉個例子:github
你定義了一些變量在base模塊中:ui
# reference data type class Demo: def __init__(self, name): self.name = name demo = Demo('Demo') # primitive type foo = 1
而後在一個模塊中用from module import 的方式讀它:this
from base import * def read(): print 'reference data id: ' + str(id(demo)) print 'reference data value : ' + demo.name print 'primitive data id: ' + str(id(foo)) print 'primitive data value: ' + str(foo)
在另一個模塊中寫它:spa
import base def write(): print "\nOriginal:" print "Original reference data id: " + str(id(base.demo)) base.demo.name = "Updated Demo" # this will reflect that change #base.demo = base.Demo("Updated Demo") # this won't relfect the change print "Original data id: " + str(id(base.foo)) base.foo = 1000 print "Original data id after assignment: " + str(id(base.foo))
而後先寫,後讀,看寫的內容是否有效:code
import read import write print "before write" read.read() write.write() print "\nafter write" read.read()
結論是沒有,緣由是:blog
這個對於object,比較容易理解,你能夠直接修改object裏的值,這個是有效的,可是當你指向另一個object時就無效了。 對於primitive類型來說,其實也是一個道理,由於每次賦值,都是讓其指向一個不一樣的內存地址,而不是inplace修改已有的那分內存 - 這個很容易驗證:內存
In [1]: a = 10 In [2]: id(a) Out[2]: 20429204 In [3]: a = 100 In [4]: id(a) Out[4]: 20430108
因此,建議是除非是一個quick and dirty的腳本,不然不要使用from module import *!get
例子:https://github.com/baiyanhuang/blog/tree/master/arena/python/from_module_import