Python在處理功能複用和功能顆粒度劃分時採用了類、模組、包的結構。這種處理跟C++中的類和名字空間類似,但更接近於Java所採用的概念。
類
類的概念在許多語言中出現,很容易理解。它將資料和操作進行封裝,以便將來的複用。
模組
模組,在Python可理解為對應於一個檔案。在建立了一個指令碼檔案後,定義了某些函式和變數。你在其他需要這些功能的檔案中,匯入這模組,就可重用這些函式和變數。一般用module_name.fun_name,和module_name.var_name進行使用。這樣的語義用法使模組看起來很像類或者名字空間,可將module_name 理解為名字限定符。模組名就是檔名去掉.py字尾。下面演示了一個簡單的例子:
#moduel1.pydef say(word): print word#caller.pyimport module1print __name__print module1.__name__module1.say("hello")$ python caller.py__main__module1hello
例子中演示了從檔案中呼叫模組的方法。這裡還展示了一個有趣的模組屬性__name__,它的值由Python直譯器設定。如果指令碼檔案是作為主程式呼叫,其值就設為__main__,如果是作為模組被其他檔案匯入,它的值就是其檔名。這個屬性非常有用,常可用來進行模組內建測試使用,你會經常在一些地方看到類似於下面的寫法,這些語句只在作為主程式呼叫時才被執行。
if __name__ == "__main__":
app = wxapp(0)
app.MainLoop()
模組搜尋路徑
上面的例子中,當module1被匯入後,python直譯器就在當前目錄下尋找module1.py的檔案,然後再從環境變數PYTHONPATH尋找,如果這環境變數沒有設定,也不要緊,直譯器還會在安裝預先設定的的一些目錄尋找。這就是在匯入下面這些標準模組,一切美好事情能發生的原因。
import os
import sys
import threading...
這些搜尋目錄可在執行時動態改變,比如將module1.py不放在當前目錄,而放在一個冷僻的角落裡。這裡你就需要透過某種途徑,如sys.path,來告知Python了。sys.path返回的是模組搜尋列表,透過前後的輸出對比和程式碼,應能理悟到如何增加新路徑的方法了吧。非常簡單,就是使用list的append()或insert()增加新的目錄。
#module2.pyimport sysimport osprint sys.pathworkpath = os.path.dirname(os.path.abspath(sys.argv[0]))sys.path.insert(0, os.path.join(workpath, "modules"))print sys.path$ python module2.py["e:\\Project\\Python", "C:\\WINDOWS\\system32\\python25.zip", ...]["e:\\Project\\Python\\modules", "e:\\Project\\Python", "C:\\WINDOWS\\system32\\python25.zip", ...]
其他的要點
模組能像包含函式定義一樣,可包含一些可執行語句。這些可執行語句通常用來進行模組的初始化工作。這些語句只在模組第一次被匯入時被執行。這非常重要,有些人以為這些語句會多次匯入多次執行,其實不然。
模組在被匯入執行時,python直譯器為加快程式的啟動速度,會在與模組檔案同一目錄下生成.pyc檔案。我們知道python是解釋性的指令碼語言,而.pyc是經過編譯後的位元組碼,這一工作會自動完成,而無需程式設計師手動執行。
包
在建立許許多多模組後,我們可能希望將某些功能相近的檔案組織在同一資料夾下,這裡就需要運用包的概念了。包對應於資料夾,使用包的方式跟模組也類似,唯一需要注意的是,當資料夾當作包使用時,資料夾需要包含__init__.py檔案,主要是為了避免將資料夾名當作普通的字串。__init__.py的內容可以為空,一般用來進行包的某些初始化工作或者設定__all__值,__all__是在from package-name import *這語句使用的,全部匯出定義過的模組。
Python在處理功能複用和功能顆粒度劃分時採用了類、模組、包的結構。這種處理跟C++中的類和名字空間類似,但更接近於Java所採用的概念。
類
類的概念在許多語言中出現,很容易理解。它將資料和操作進行封裝,以便將來的複用。
模組
模組,在Python可理解為對應於一個檔案。在建立了一個指令碼檔案後,定義了某些函式和變數。你在其他需要這些功能的檔案中,匯入這模組,就可重用這些函式和變數。一般用module_name.fun_name,和module_name.var_name進行使用。這樣的語義用法使模組看起來很像類或者名字空間,可將module_name 理解為名字限定符。模組名就是檔名去掉.py字尾。下面演示了一個簡單的例子:
#moduel1.pydef say(word): print word#caller.pyimport module1print __name__print module1.__name__module1.say("hello")$ python caller.py__main__module1hello
例子中演示了從檔案中呼叫模組的方法。這裡還展示了一個有趣的模組屬性__name__,它的值由Python直譯器設定。如果指令碼檔案是作為主程式呼叫,其值就設為__main__,如果是作為模組被其他檔案匯入,它的值就是其檔名。這個屬性非常有用,常可用來進行模組內建測試使用,你會經常在一些地方看到類似於下面的寫法,這些語句只在作為主程式呼叫時才被執行。
if __name__ == "__main__":
app = wxapp(0)
app.MainLoop()
模組搜尋路徑
上面的例子中,當module1被匯入後,python直譯器就在當前目錄下尋找module1.py的檔案,然後再從環境變數PYTHONPATH尋找,如果這環境變數沒有設定,也不要緊,直譯器還會在安裝預先設定的的一些目錄尋找。這就是在匯入下面這些標準模組,一切美好事情能發生的原因。
import os
import sys
import threading...
這些搜尋目錄可在執行時動態改變,比如將module1.py不放在當前目錄,而放在一個冷僻的角落裡。這裡你就需要透過某種途徑,如sys.path,來告知Python了。sys.path返回的是模組搜尋列表,透過前後的輸出對比和程式碼,應能理悟到如何增加新路徑的方法了吧。非常簡單,就是使用list的append()或insert()增加新的目錄。
#module2.pyimport sysimport osprint sys.pathworkpath = os.path.dirname(os.path.abspath(sys.argv[0]))sys.path.insert(0, os.path.join(workpath, "modules"))print sys.path$ python module2.py["e:\\Project\\Python", "C:\\WINDOWS\\system32\\python25.zip", ...]["e:\\Project\\Python\\modules", "e:\\Project\\Python", "C:\\WINDOWS\\system32\\python25.zip", ...]
其他的要點
模組能像包含函式定義一樣,可包含一些可執行語句。這些可執行語句通常用來進行模組的初始化工作。這些語句只在模組第一次被匯入時被執行。這非常重要,有些人以為這些語句會多次匯入多次執行,其實不然。
模組在被匯入執行時,python直譯器為加快程式的啟動速度,會在與模組檔案同一目錄下生成.pyc檔案。我們知道python是解釋性的指令碼語言,而.pyc是經過編譯後的位元組碼,這一工作會自動完成,而無需程式設計師手動執行。
包
在建立許許多多模組後,我們可能希望將某些功能相近的檔案組織在同一資料夾下,這裡就需要運用包的概念了。包對應於資料夾,使用包的方式跟模組也類似,唯一需要注意的是,當資料夾當作包使用時,資料夾需要包含__init__.py檔案,主要是為了避免將資料夾名當作普通的字串。__init__.py的內容可以為空,一般用來進行包的某些初始化工作或者設定__all__值,__all__是在from package-name import *這語句使用的,全部匯出定義過的模組。