Python函數(shù)學習筆記
更新時間:2008年10月07日 23:49:40 作者:
Python探測局部作用域的時候:是在python編譯代碼時檢測,而不是通過他們在運行時的賦值。
局部名字靜態(tài)檢測
Python探測局部作用域的時候:是在python編譯代碼時檢測,而不是通過他們在運行時的賦值。
正常的情況下,沒在函數(shù)中復制的名字將在包含它的模塊中查找:
>>> x=99
>>> def selector():
... print x
...
>>> selector()
99
但是:
>>> def selector():
... print x
... x=100
...
>>> selector()
Traceback (most recent call last):
File "<stdin>", line 1, in ?
File "<stdin>", line 2, in selector
UnboundLocalError: local variable 'x' referenced before assignment
會得到未定義名字的錯誤。
當 交互式輸入或從一個模塊中導入時,python讀取并編譯這段代碼,當編譯時python查看x的賦值,并決定在函數(shù)中任何地方x都將是個局部名字。到后 來函數(shù)真的運行,print執(zhí)行時,賦值還沒有發(fā)生,python會說你正在使用一個未定義的名字。根據(jù)他的名字規(guī)則,應該是局部的x在賦值前被使用了。
解決辦法:
如果你想打印全局x,你應該在global語句中聲明:(這意味著該賦值也改變全局x,而不是局部x)
>>> def selector():
... global x
... print x
... x=88
...
>>> selector()
99
如果你想打印出全局賦值,在設定一個局部的,導入包含它的模塊并用限定得到這個全局的版本:
>>> x=99
>>> def selector():
... import __main__
... print __main__.x
... x=88
... print x
...
>>> selector()
99
88
限定(.x部分)從一個名字空間對象中得到一個值。交互環(huán)境的名字空間是一個叫做__main__的模塊。
嵌套函數(shù)可以嵌套作用域(在新版本中和老版本中不同)
>>> def outer(x):
... def inner(i):
... print i,
... if i: inner(i-1)
... inner(x)
...
>>> outer(3)
3 2 1 0
使用默認值保存引用
>>> def outer(x):
... def inner(i,self=inner):
... print i,
... if i:self(i-1)
... inner(x)
...
>>> outer(3)
Traceback (most recent call last):
File "<stdin>", line 1, in ?
File "<stdin>", line 2, in outer
UnboundLocalError: local variable 'inner' referenced before assignment
解決原則:最簡單的方式總是最正確的方式
>>> def inner(i):
... print i,
... if i:inner(i-1)
...
>>> def outer(x):
... inner(x)
...
>>> outer(3)
3 2 1 0
默認的可變對象
>>> def saver(x=[]):
... x.append(1)
... print x
...
>>> saver([2])
[2, 1]
>>> saver()
[1]
>>> saver()
[1, 1]
>>> saver()
[1, 1, 1]
問題是,這里只有一個列表對象——def執(zhí)行時生成的一個。在每一次函數(shù)被調用時,你不會得到新的列表對象,而是原列表對象的增長。
解決辦法:如果那不是你想要的行為,簡單的移動默認值到函數(shù)體中。只要代碼里的值在每一次函數(shù)運行時都執(zhí)行,你每次將得到一個新的對象:
>>> def saver(x=None):
... if x is None:
... x=[]
... x.append(1)
... print x
...
>>> saver([2])
[2, 1]
>>> saver()
[1]
>>> saver()
[1]
>>> saver()
[1]
上 面的if語句幾乎可以被賦值x=x or []代替,因為python的or將返回他的操作對象中的一個:如果沒有參數(shù)被傳遞,x默認為None,所以or在右側返回一個生成的空列表。但這不完全 一樣,當傳遞的是空列表時,函數(shù)將擴展并返回一個新生成的列表,而不是向前面的版本那樣擴展并返回一個被傳遞的列表(表達式變成[] or [],這將計算出新的列表)
Python探測局部作用域的時候:是在python編譯代碼時檢測,而不是通過他們在運行時的賦值。
正常的情況下,沒在函數(shù)中復制的名字將在包含它的模塊中查找:
>>> x=99
>>> def selector():
... print x
...
>>> selector()
99
但是:
>>> def selector():
... print x
... x=100
...
>>> selector()
Traceback (most recent call last):
File "<stdin>", line 1, in ?
File "<stdin>", line 2, in selector
UnboundLocalError: local variable 'x' referenced before assignment
會得到未定義名字的錯誤。
當 交互式輸入或從一個模塊中導入時,python讀取并編譯這段代碼,當編譯時python查看x的賦值,并決定在函數(shù)中任何地方x都將是個局部名字。到后 來函數(shù)真的運行,print執(zhí)行時,賦值還沒有發(fā)生,python會說你正在使用一個未定義的名字。根據(jù)他的名字規(guī)則,應該是局部的x在賦值前被使用了。
解決辦法:
如果你想打印全局x,你應該在global語句中聲明:(這意味著該賦值也改變全局x,而不是局部x)
>>> def selector():
... global x
... print x
... x=88
...
>>> selector()
99
如果你想打印出全局賦值,在設定一個局部的,導入包含它的模塊并用限定得到這個全局的版本:
>>> x=99
>>> def selector():
... import __main__
... print __main__.x
... x=88
... print x
...
>>> selector()
99
88
限定(.x部分)從一個名字空間對象中得到一個值。交互環(huán)境的名字空間是一個叫做__main__的模塊。
嵌套函數(shù)可以嵌套作用域(在新版本中和老版本中不同)
>>> def outer(x):
... def inner(i):
... print i,
... if i: inner(i-1)
... inner(x)
...
>>> outer(3)
3 2 1 0
使用默認值保存引用
>>> def outer(x):
... def inner(i,self=inner):
... print i,
... if i:self(i-1)
... inner(x)
...
>>> outer(3)
Traceback (most recent call last):
File "<stdin>", line 1, in ?
File "<stdin>", line 2, in outer
UnboundLocalError: local variable 'inner' referenced before assignment
解決原則:最簡單的方式總是最正確的方式
>>> def inner(i):
... print i,
... if i:inner(i-1)
...
>>> def outer(x):
... inner(x)
...
>>> outer(3)
3 2 1 0
默認的可變對象
>>> def saver(x=[]):
... x.append(1)
... print x
...
>>> saver([2])
[2, 1]
>>> saver()
[1]
>>> saver()
[1, 1]
>>> saver()
[1, 1, 1]
問題是,這里只有一個列表對象——def執(zhí)行時生成的一個。在每一次函數(shù)被調用時,你不會得到新的列表對象,而是原列表對象的增長。
解決辦法:如果那不是你想要的行為,簡單的移動默認值到函數(shù)體中。只要代碼里的值在每一次函數(shù)運行時都執(zhí)行,你每次將得到一個新的對象:
>>> def saver(x=None):
... if x is None:
... x=[]
... x.append(1)
... print x
...
>>> saver([2])
[2, 1]
>>> saver()
[1]
>>> saver()
[1]
>>> saver()
[1]
上 面的if語句幾乎可以被賦值x=x or []代替,因為python的or將返回他的操作對象中的一個:如果沒有參數(shù)被傳遞,x默認為None,所以or在右側返回一個生成的空列表。但這不完全 一樣,當傳遞的是空列表時,函數(shù)將擴展并返回一個新生成的列表,而不是向前面的版本那樣擴展并返回一個被傳遞的列表(表達式變成[] or [],這將計算出新的列表)
相關文章
淺談opencv自動光學檢測、目標分割和檢測(連通區(qū)域和findContours)
這篇文章主要介紹了淺談opencv自動光學檢測、目標分割和檢測(連通區(qū)域和findContours),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06
python 實現(xiàn)對文件夾中的圖像連續(xù)重命名方法
今天小編就為大家分享一篇python 實現(xiàn)對文件夾中的圖像連續(xù)重命名方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10
Python數(shù)據(jù)可視化之matplotlib.pyplot繪圖的基本參數(shù)詳解
matplotlib.pyplot模塊是一個功能強大的畫圖模塊,可以對畫圖的多個參數(shù)進行調整,下面這篇文章主要給大家介紹了關于Python數(shù)據(jù)可視化之matplotlib.pyplot繪圖基本參數(shù)的相關資料,需要的朋友可以參考下2022-04-04
Python?Requests?基本使用及Requests與?urllib?區(qū)別
在使用Python爬蟲時,需要模擬發(fā)起網絡請求,主要用到的庫有requests庫和python內置的urllib庫,一般建議使用requests,它是對urllib的再次封裝,今天通過本文給大家講解Python?Requests使用及urllib區(qū)別,感興趣的朋友一起看看吧2022-11-11

