在交互模式下,return的結果會自動打印出來,而做爲腳本單獨運行時則須要print函數才能顯示。blog
return 語句就是講結果返回到調用的地方,並把程序的控制權一塊兒返回python
程序運行到所遇到的第一個return即返回(退出def塊),不會再運行第二個return。閉包
要返回兩個數值,寫成一行便可:app
def a(x,y): if x==y: return x,y print a(3,3)<br><br>>>> 3,3
可是也並不意味着一個函數體中只能有一個return 語句,例如:函數
def test_return(x): if x > 0: return x else: return 0
函數沒有 return,默認 return一個 None 對象。post
遞歸函數中沒有return 的狀況:spa
def gcd(a,b): if a%b==0: return b else: gcd(b,a%b)
分析:else 中沒有 return 就沒有出口,這個程序是本身內部運行,程序沒有返回值, code
python 和 print 的區別:對象
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的結果會自動打印出來,而做爲腳本單獨運行時則須要print函數才能顯示。blog
def func(): try: print 98 return 'ok' #函數獲得了一個返回值 finally: #finally語句塊中的語句依然會執行 print 98 print fun()
輸出:遞歸
98
98
ok
函數做爲返回值返回:
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 並無執行,而是返回一個指向求和的函數的函數名sum 的內存地址。 f=lazy_sum(1,2,3,4,5,6,7,8,9) print(type(f)) print(f()) # 調用f()函數,才真正調用了 sum 函數進行求和,
這其實就是閉包。
返回一個函數列表:
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
執行過程:
當i=1, 執行for循環, 結果返回函數f的函數地址,存在列表fs中的第一個位置上。
當i=2, 因爲fs列表中第一個元素所指的函數中的i是count函數的局部變量,i也指向了2;而後執行for循環, 結果返回函數f的函數地址,存在列表fs中的第二個位置上。
當i=3, 同理,在fs列表第一個和第二個元素所指的函數中的i變量指向了3; 而後執行for循環, 結果返回函數f的函數地址,存在列表fs中的第三個位置上。
因此在調用f1()的時候,函數中的i是指向3的:
f1():
return 3*3
同理f2(), f3()結果都爲9
閉包時牢記的一點就是:返回函數不要引用任何循環變量,或者後續會發生變化的變量。即包在裏面的函數(本例爲f()),不要引用外部函數(本例爲count())的任何循環變量
若是必定要引入循環變量,方法是再建立一個函數,用該函數的參數綁定循環變量當前的值,不管該循環變量後續如何更改,已綁定到函數參數的值不變:
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())