Python return語句如何實現(xiàn)結(jié)果返回調(diào)用
return 語句就是講結(jié)果返回到調(diào)用的地方,并把程序的控制權(quán)一起返回
程序運行到所遇到的第一個return即返回(退出def塊),不會再運行第二個return。
要返回兩個數(shù)值,寫成一行即可:
def a(x,y):
if x==y:
return x,y
print a(3,3)<br><br>>>> 3,3
但是也并不意味著一個函數(shù)體中只能有一個return 語句,例如:
def test_return(x):
if x > 0:
return x
else:
return 0
函數(shù)沒有 return,默認(rèn) return一個 None 對象。
遞歸函數(shù)中沒有return 的情況:
def gcd(a,b):
if a%b==0:
return b
else:
gcd(b,a%b)
分析:else 中沒有 return 就沒有出口,這個程序是自己內(nèi)部運行,程序沒有返回值,
python 和 print 的區(qū)別:
x = 1 y = 2 def add (x, y): z = x + y return z print (add(x,y) x = 1 y = 2 def add (x, y): z = x + y print z print (add(x,y))
在交互模式下,return的結(jié)果會自動打印出來,而作為腳本單獨運行時則需要print函數(shù)才能顯示。
默認(rèn)情況下,遇見 return 函數(shù)就會返回給調(diào)用者,但是 try,finally情況除外:
def func():
try:
print 98
return 'ok' #函數(shù)得到了一個返回值
finally: #finally語句塊中的語句依然會執(zhí)行
print 98
print fun()
輸出:
98
98
ok
函數(shù)作為返回值返回:
標(biāo)簽: python
def lazy_sum(*args):
def sum():
x=0
for n in args:
x=x+n
return x
return sum
lazy_sum(1,2,3,4,5,6,7,8,9) #這時候lazy_sum 并沒有執(zhí)行,而是返回一個指向求和的函數(shù)的函數(shù)名sum 的內(nèi)存地址。
f=lazy_sum(1,2,3,4,5,6,7,8,9)
print(type(f))
print(f()) # 調(diào)用f()函數(shù),才真正調(diào)用了 sum 函數(shù)進行求和,
這其實就是閉包。
返回一個函數(shù)列表:
def count():
fs = []
for i in range(1,4):
def f():
return i*i
fs.append(f)
return fs
f1, f2, f3 = count()
print(f1())
print(f2())
print(f3())
輸出:
9
9
9
執(zhí)行過程:
當(dāng)i=1, 執(zhí)行for循環(huán), 結(jié)果返回函數(shù)f的函數(shù)地址,存在列表fs中的第一個位置上。
當(dāng)i=2, 由于fs列表中第一個元素所指的函數(shù)中的i是count函數(shù)的局部變量,i也指向了2;然后執(zhí)行for循環(huán), 結(jié)果返回函數(shù)f的函數(shù)地址,存在列表fs中的第二個位置上。
當(dāng)i=3, 同理,在fs列表第一個和第二個元素所指的函數(shù)中的i變量指向了3; 然后執(zhí)行for循環(huán), 結(jié)果返回函數(shù)f的函數(shù)地址,存在列表fs中的第三個位置上。
所以在調(diào)用f1()的時候,函數(shù)中的i是指向3的:
f1():
return 3*3
同理f2(), f3()結(jié)果都為9
閉包時牢記的一點就是:返回函數(shù)不要引用任何循環(huán)變量,或者后續(xù)會發(fā)生變化的變量。即包在里面的函數(shù)(本例為f()),不要引用外部函數(shù)(本例為count())的任何循環(huán)變量
如果一定要引入循環(huán)變量,方法是再創(chuàng)建一個函數(shù),用該函數(shù)的參數(shù)綁定循環(huán)變量當(dāng)前的值,無論該循環(huán)變量后續(xù)如何更改,已綁定到函數(shù)參數(shù)的值不變:
def count():
fs=[]
for i in range(1,4):
def f(j):
def g():
return j*j
return g
fs.append(f(i))
return fs
f1,f2,f3=count()
print(f1())
print(f2())
print(f3())
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python利用keras接口實現(xiàn)深度神經(jīng)網(wǎng)絡(luò)回歸
這篇文章主要為大家詳細(xì)介紹了基于Python語言中TensorFlow的Keras接口,實現(xiàn)深度神經(jīng)網(wǎng)絡(luò)回歸的方法。文中的示例代碼講解詳細(xì),感興趣的可以了解一下2023-02-02
python GUI庫圖形界面開發(fā)之PyQt5滾動條控件QScrollBar詳細(xì)使用方法與實例
這篇文章主要介紹了python GUI庫圖形界面開發(fā)之PyQt5滾動條控件QScrollBar詳細(xì)使用方法與實例,需要的朋友可以參考下2020-03-03
Python中使用defaultdict和Counter的方法
本文深入探討了Python中的兩個強大工具——defaultdict和Counter,并詳細(xì)介紹了它們的工作原理、應(yīng)用場景以及在實際編程中的高效使用方法,感興趣的朋友跟隨小編一起看看吧2025-01-01
Python處理JSON數(shù)據(jù)并導(dǎo)入Neo4j數(shù)據(jù)庫
在數(shù)據(jù)處理和分析中,JSON是一種常見的數(shù)據(jù)格式,Neo4j是一個高性能的圖數(shù)據(jù)庫,能夠存儲和查詢復(fù)雜的網(wǎng)絡(luò)關(guān)系,下面我們就來看看Python如何處理JSON數(shù)據(jù)并導(dǎo)入Neo4j數(shù)據(jù)庫吧2024-11-11

