Python 基礎-import 與 from...import....


簡單說說python import與from…import…

在python用import或者from…import來導入相應的模塊。模塊其實就一些函數和類的集合文件,它能實現一些相應的功能,當我們需要使用這些功能的時候,直接把相應的模塊導入到我們的程序中,我們就可以使用了。這類似於C語言中的include頭文件,Python中我們用import導入我們需要的模塊。

import sys
print('================Python import mode==========================');
print ('The command line arguments are:')
for i in sys.argv:
    print (i)
print ('\n The python path',sys.path)

from sys import argv,path #導入特定的成員
print('================python from import===================================')
print('path:',path)

如果你要使用所有sys模塊使用的名字,你可以這樣:

from sys import *
print('path:',path)

從以上我們可以簡單看出:
導入mode,import與from…import的不同之處在於,簡單說:
如果你想要直接輸入argv變量到你的程序中而每次使用它時又不想打sys,
則可使用:from sys import argv
一般說來,應該避免使用from…import而使用import語句,
因為這樣可以使你的程序更加易讀,也可以避免名稱的沖突

在使用 from xxx import * 時,如果想精准的控制模塊導入的內容,可以使用 all = [xxx,xxx] 來實現,例如:

two.py

__all__ = ['a','b'] #__為雙橫線
class two():
    def __init__(self):
        print('this is two')
a = 'this is two a'
b = 'this is two b'
if __name__=='__main__':
    t = two()
one.py

from two import *
print a
print b
t = two()

這時,類two() 將不會被import * 導入進來

關於Import中的路徑搜索問題

類似於頭文件,模塊也是需要系統的搜索路徑的,下面的命令即是系統默認的搜索路徑,當你導入一個模塊時,系統就會在下面的路徑列表中搜索相應的文件。

print(sys.path)
['/home/python/code', '/usr/lib64/python26.zip', '/usr/lib64/python2.6', '/usr/lib64/python2.6/plat-linux2', '/usr/lib64/python2.6/lib-tk', '/usr/lib64/python2.6/lib-old', '/usr/lib64/python2.6/lib-dynload', '/usr/lib64/python2.6/site-packages', '/usr/lib/python2.6/site-packages']

(從例表中,我們可以看到python會首先在當前工作目錄里去找)

如果沒有找到相應的內容,則報錯:

import syss

Traceback (most recent call last):
  File "D:/xxx/xxx/xx/Code/test.py", line 19, in <module>
    import syss
ImportError: No module named syss

當然,我們也可以自行添加要搜索路徑。調用列表的append方法即可:

import sys
sys.path.append('/home/python/newcode')

創建自己的模塊

在創建之前,有一點需要說明一下:每個Python模塊都有它的__name__(就每個對象都自己的__doc__一樣)。通過__name__我們可以找出每一個模塊的名稱,一般__name__的值有兩種:1 一是主模塊名稱為:“main”(可以理解為直接運行的那個文件),2 那些被主模塊導入的模塊名稱為:文件名字(不加后面的.py)。有__name__是很有用的,因為我們可以通過 if name == ‘xxx’ 判斷來執行那些模塊,那些模塊不被執行。另外:每個Python程序也是一個模塊。它擴展名為:.py擴展名。

下面,我們通過例子來說明:
首先:我們創建模塊:mymodel.py

#!/user/bin/python
#Filename:mymodel.py
version = '1.0'
def sayHello():
    print ('Hello world')

def modelName():
    return __name__#返回它自己的名稱
#end of model

以上語句注意:

1.這個模塊應該被放置在我們輸入它的程序的同一個目錄中,或者在sys.path所列目錄之一。
2.你已經看到,它與我們普通的Python程序相比並沒有什么特別之處

然后:我們在test.py中來調用此模塊:test.py

import sys,mymodel
sys.path.append('/home/python/newcode')#提供搜索路徑
print(__name__) #此處打印主模塊的名稱:__main__
mymodel.sayHello()
print('Version',mymodel.version)
print('Model Name',mymodel.modelName())#打印被導入模塊的名稱: mymodel

我們使用from…import…

print('======================from.....import=====================================')
from mymodel import *
print(__name__)#此處打印主模塊的名稱:__main__
sayHello()
print('Version',version)
print('Model Name',modelName()) #打印被導入模塊的名稱: mymodel

以上語句注意:

1.我們可以通過import來導入多個模塊,用“,”(逗號)分隔。
2.注意import與from…import…

創建自己的包

1.一個包的基本組織如下:
FC/
  __init__.py
  Libr/
    __init__.py
    one.py
    two.py
    ....
  Model/
    __init__.py
    one.py
    ....

在外部加載調用時,有以下方式:
coding:utf-8
加載方式一
import Fc.Libr.one
print Fc.Libr.one.a
加載方式二
from Fc.Libr import one
print one.a
加載方式三
from Fc.Libr.one import a
print a
加載方式四
from Fc.Libr import *
print one.a

注意直接使用第四種方式是不能正確導入Libr下的one子模塊的,這就需要在Fc目錄下的__init__.py文件中定義好需要加載子模塊的名稱

Fc/Libr/__init__.py
__all__=['one','two'] #定義加載子模塊的名稱

在加載包模塊時,在import語句執行期時,遇到的所有__init__.py文件都會被執行,在上面代碼中
首先會執行Fc目錄中的__int__.py,然后執行Libr目錄中的__init__.py

2.子模塊加子模塊問題

同一包的相同目錄中:

#coding:utf-8
#加載方式一:使用完全限定名稱
from Fc.Libr import one
aa = 'libr two load one---'+one.a

#加載方式二:使用相對導入
from . import one
bb = 'libr two load one----'+one.b
方二中使用.來表示在同一級目錄中。


#加載方式三:(這種方式應當避免:最后找不到會轉移到標准庫)
import Fc.Libr.one
cc = 'libr two load one---'+Fc.Libr.one.a

在外部使用時:
#coding:utf-8
from Fc.Libr import *
print two.aa
print two.bb

同一包的不同目錄中:

#coding:utf-8
from ..Model import one
a = 'libr two load mode one---'+one.a

使用時:
#coding:utf-8
from Fc.Libr import *
print two.a
將輸出:libr two load mode one---fc model one

另外在導入一個包時,會定義一個特殊的變量__path__,該變量包含一個目錄列表。
__path__可通過__init__.py文件中包含的代碼訪問,最初包含的一項具有包的目錄名稱。我們可以
向__path__列表提供更多的目錄,以更改查找子模塊時使用的搜索路徑,大型項目中這個很有用。

特別說明
1.import執行加載源文件中所有語名(所以模塊是一個文件)。
2.import語句可以出現在程序中的任何位置。但是有一點是:無論import語句被使用了多少次,每個模塊中的代碼僅加載和執行一次,后續的import語句僅將模塊名稱綁定到前一次導入所創建的模塊對象上。
3.值有種使用sys.modules可查看當前加載的所有模塊。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM