在表達式中引用變量時,Python 會按照如下的順序遍歷各個作用域,尋找該變量:
- 當前函數作用域
- 任何外圍作用域(比如包含當前函數的其他函數)
-
global 作用域,即代碼所在的模塊的作用域
如果上述作用域內都找不到變量,就會報 NameError 異常。
但是對變量賦值時,規則會有所不同。
- 如果當前作用域變量已存在,那么其值會被替換。
-
如果不存在,則會視為在當前作用域定義新變量,而不是向外圍作用域中尋找。
如下函數
def function(): flag = True def helper(): flag = False helper() print flag function()
由于 helper 中變量是賦值,這里 flag 輸出仍為 True。習慣了 c 語言之類靜態類型語言,這種設計起初會感到困惑,但其可以有效地防止局部變量污染函數外的環境。
需求總是多樣的,一定有程序員想在賦值時訪問外圍作用域。如果是 Python2,他可以這么做
def function(): flag = [True] def helper(): flag[0] = False helper() print flag function()
先用 flag[0] 是讀操作,產生一次變量引用,尋找到外圍作用域中 flag,這時候再賦值 flag[0] = False 便不會新定義變量了。
如果是 Python3,則可以使用 nonlocal 關鍵字。
def function(): flag = True def helper(): nonlocal flag flag = False helper() print flag function()
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
