Python包機制
>本文作者:黎智煊,叩丁狼高階講師。原創文章,轉載請註明出處。
在介紹包機制,首先再次回顧一下關於python的模組知識.
-
Python 模組
- Python 模組(Module),是一個 Python 檔案,以 .py 結尾,包含了 Python 物件定義和Python語句。
- 模組讓你能夠有邏輯地組織你的 Python 程式碼段。
- 把相關的程式碼分配到一個模組裡能讓你的程式碼更好用,更易懂。
- 模組能定義函式,類和變數,模組裡也能包含可執行的程式碼。
例子
下例是個簡單的模組 support.py:
support.py 模組: def print_func( par ): print ("Hello : %s"%par return
-
import 語句
模組的引入 模組定義好後,我們可以使用 import 語句來引入模組,語法如下:
import module1[, module2[,... moduleN]]
比如要引用模組 math,就可以在檔案最開始的地方用 import math 來引入。在呼叫 math 模組中的函式時,必須這樣引用:
模組名.函式名
當直譯器遇到 import 語句,如果模組在當前的搜尋路徑就會被匯入。
搜尋路徑是一個直譯器會先進行搜尋的所有目錄的列表。如想要匯入模組 support.py,需要把命令放在指令碼的頂端:
test.py 檔案程式碼:
#!/usr/bin/python import support # 現在可以呼叫模組裡包含的函數了 support.print_func("wolfcode") 以上例項輸出結果: Hello : wolfcode
一個模組只會被匯入一次,不管你執行了多少次import。這樣可以防止匯入模組被一遍又一遍地執行。
-
from…import 語句
Python 的 from 語句讓你從模組中匯入一個指定的部分到當前名稱空間中。語法如下:
from modname import name1[, name2[, ... nameN]]
例如,要匯入模組 fib 的 fibonacci 函式,使用如下語句:
from fib import fibonacci
這個宣告不會把整個 fib 模組匯入到當前的名稱空間中,它只會將 fib 裡的 fibonacci 單個引入到執行這個宣告的模組的全域性符號表。
-
from…import* 語句
把一個模組的所有內容全都匯入到當前的名稱空間也是可行的,只需使用如下宣告:
from modname import *
這提供了一個簡單的方法來匯入一個模組中的所有專案。然而這種宣告不該被過多地使用。
例如我們想一次性引入 math 模組中所有的東西,語句如下:
from math import *
-
搜尋路徑
當你匯入一個模組,Python 解析器對模組位置的搜尋順序是:
- 當前目錄
- 如果不在當前目錄,Python 則搜尋在 shell 變數 PYTHONPATH 下的每個目錄。
- 如果都找不到,Python會察看預設路徑。UNIX下,預設路徑一般為/usr/local/lib/python/。
模組搜尋路徑儲存在 system 模組的 sys.path 變數中。變數裡包含當前目錄,PYTHONPATH和由安裝過程決定的預設目錄。
PYTHONPATH 變數
作為環境變數,PYTHONPATH 由裝在一個列表裡的許多目錄組成。PYTHONPATH 的語法和 shell 變數 PATH 的一樣。
在 Windows 系統,典型的 PYTHONPATH 如下:
set PYTHONPATH=c:\python27\lib;
在 UNIX 系統,典型的 PYTHONPATH 如下:
set PYTHONPATH=/usr/local/lib/python
名稱空間和作用域
變數是擁有匹配物件的名字(識別符號)。名稱空間是一個包含了變數名稱們(鍵)和它們各自相應的物件們(值)的字典。
-
一個 Python 表示式可以訪問區域性名稱空間和全域性名稱空間裡的變數。如果一個區域性變數和一個全域性變數重名,則區域性變數會覆蓋全域性變數。
-
每個函式都有自己的名稱空間。類的方法的作用域規則和通常函式的一樣。
-
Python 會智慧地猜測一個變數是區域性的還是全域性的,它假設任何在函式內賦值的變數都是區域性的。
因此,如果要給函式內的全域性變數賦值,必須使用 global 語句。
global VarName 的表示式會告訴 Python, VarName 是一個全域性變數,這樣 Python 就不會在區域性名稱空間裡尋找這個變量了。
例如,我們在全域性名稱空間裡定義一個變數 Money。我們再在函式內給變數 Money 賦值,然後 Python 會假定 Money 是一個區域性變數。然而,我們並沒有在訪問前宣告一個區域性變數 Money,結果就是會出現一個 UnboundLocalError 的錯誤。取消 global 語句的註釋就能解決這個問題。
Money = 2000
def AddMoney():
# 想改正程式碼就取消以下注釋:
# global Money
Money = Money + 1
print Money
AddMoney()
print Money