python中 return 的用法
return 语句就是讲结果返回到调用的地方,并把程序的控制权一起返回
程序运行到所遇到的第一个return即返回(退出def块),不会再运行第二个return。
要返回两个数值,写成一行即可:
def a(x,y):
if x==y:
return x,y
print a(3,3)
>>> 3,3
但是也并不意味着一个函数体中只能有一个return 语句,例如:
def test_return(x):
if x > 0:
return x
else:
return 0
函数没有 return,默认 return一个 None 对象。
递归函数中没有return 的情况:
def gcd(a,b):
if a%b==0:
return b
else:
gcd(b,a%b)
分析:else 中没有 return 就没有出口,这个程序是自己内部运行,程序没有返回值,
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函数才能显示。
默认情况下,遇见 return 函数就会返回给调用者,但是 try,finally情况除外:
复制代码
def func():
try:
print 98
return ‘ok’ #函数得到了一个返回值
finally: #finally语句块中的语句依然会执行
print 98
print fun()
复制代码
输出:
98
98
ok
函数作为返回值返回:
标签: 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 并没有执行,而是返回一个指向求和的函数的函数名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 fsf1, 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 fsf1,f2,f3=count()
print(f1())
print(f2())
print(f3())
复制代码