python基础只是——函数(中)
1. 函数的返回值
- 返回值就是函数执行以后返回的结果
- 通过return来指定函数的返回值
- return后面可以跟任意对象,返回值甚至可以是一个函数`
def fun(*args):
r = 0
for i in args:
r += i
print(r)
return r #返回r的值,但是在函数外不能使用r这个名字
#返回值的类型(可以返回任何类型的数据)
return [1,2,3] #列表
return 0 #整型
return 'zbc' #字符串
return 3.125 #浮点数
return (1,2,3) #元组
return {1,2,3} #集合
return{'a':1,'b':2} #字典
return True #布尔
def fun_1():
pass
return fun_1 #函数
print(fun(1,2,3)) #获得函数的返回值的结果
res = fun(1,2,3) #res=fun() res=fun()() = fun_1() 调用fun_1()
print(res)
'''
一个函数,要想有返回值,必须写return xxx,如果没有return 和 只有一个return没有返回对象,那么这个函数的返回值都是None
'''
def fun_2():
print(1)
return #return后面的代码都不再执行,看到return会直接退出函数
print(2)
print(fun_2())
2. 文档字符串
- help()是Python中内置函数,通过help()函数可以查询Python中函数的用法
- 在定义函数时,可以在函数内部编写文档字符串,文档字符串就是对函数的说明
'''
#长字符串:
1、保留文本的格式
2、作为一个多行注释
'''
#文档字符串,就是对函数以和类进行说明作用、参数传递及返回值的一个文档说明
def fun(a,b):
"""
:param a:
:param b:
:return:
"""
help(print)
help(input)
3. 函数的作用域
- 作用域(scope)
- 作用域指的是变量生效的区域
- 在Python中一共有两种作用域
• 全局作用域(全局变量)
• 全局作用域在程序执行时创建,在程序执行结束时销毁
• 所有函数以外的区域都是全局作用域
• 在全局作用域中定义的变量,都是全局变量,全局变量可以在程序的任意位置进行访问
a = 1 #在任何位置使用
def fun(*args):
r = 0
for i in args:
r += i
print(a)
• 函数作用域(局部变量)
• 函数作用域在函数调用时创建,在调用结束时销毁
• 函数每调用一次就会产生一个新的函数作用域
• 在函数作用域中定义的变量,都是局部变量,它只能在函数内部被访问
a = 1 #全局变量
def fun():
#a = 1
#使局部变量变成全局变量的方法
global a #声明此处的变量a是全局变量
a = 10 #局部变量,相当于a重新赋值
print(a)
def fun1(): #函数在fun()内,使用局部变量
print(a)
fun1()
fun()
print(a)
4. 命名空间
- 命名空间实际上就是一个字典,是一个专门用来存储变量的字典
- locals()用来获取当前作用域的命名空间
- 如果在全局作用域中调用locals()则获取全局命名空间,如果在函数作用域中调用locals()则获取函数命名空间
- 返回值是一个字典
a = 1
b = 2
c = 3
s = locals() #获取当前作用域的所有变量,并且以一个字典的形式返回出来
print(s)
def fun():
a = 1
b = 2
s = locals() #获取局部作用域的命名空间
#s = global() #获取全局作用域的命名空间
print(s)
pass
#结果
’‘’
{'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x00000207B4A34820>, '__spec__': None, '__annotations__': {}, '__builtins__': <module 'builtins' (built-in)>, '__file__': 'D:\\pycharm-professional-2020.3.3\\project\\python基础\\函数(中)\\命名空间.py', '__cached__': None, 'a': 1, 'b': 2, 'c': 3, 's': {...}}
‘’‘
5. 递归函数
• 递归是解决问题的一种方式,它的整体思想,是将一个大问题分解为一个个的小问题,直到问题无法分解时,在去解决问题
• 递归式函数有2个条件
• 1. 基线条件 问题可以被分解为最小问题,当满足基线条件时,递归就不执行了
• 2. 递归条件 可以将问题继续分解的条件
#递归函数就是自己引用自己,递归函数就是在函数里自己调用自己
# 无穷递归
def fun():
fun()
fun()
#递归的两个条件
# 1.基线条件:问题可以被分解为最小的问题,当满足基线条件的时候,再去解决问题
# 2.递归条件:将问题继续分解的条件
- 递归练习
#求取10的阶乘
# 10! = 10*9! n! = n*(n-1)! =》 fun(n) = n*fun(n-1)
# 9! = 9*8!
# ....
# 1!=1 基线条件
def fun(n): #fun(n)是为了求取n的阶乘
if n==1:
return 1
return n*fun(n-1)
print(fun(10))
# 任意数的任意次幂
# 10 ** 5 = 10 * 10 ** 4
# 10 ** 4 = 10 * 10 ** 3
# 10 ** 1 = 10
def fun(n,m):
if m == 1:
return n
return n * fun(n,m-1)
print(fun(10,6))
# 求一个字符串是否是回文字符串
#123456789987654321 12345678987654321
# 123456789987654321 12345678987654321
# 2345678998765432 234567898765432
# 34567899876543 3456789876543
# 99 9
def fun(s):
if len(s)<2:
return True
elif s[0] != s[-1]:
return False
return fun(s[1:-1])
print(fun('123456789987654321'))
6.练习
- 用函数实现一个判断用户输入的年份是否是闰年的程序
1.能被400整除的年份
2.能被4整除,但是不能被100整除的年份
以上2种方法满足一种即为闰年
'''1. 用函数实现一个判断用户输入的年份是否是闰年的程序
1.能被400整除的年份
2.能被4整除,但是不能被100整除的年份
以上2种方法满足一种即为闰年
'''
def fun():
try:
year = int(input("请输入年份:"))
if year//400 == 0:
print('输入的年份是{},并且为闰年'.format(year))
elif year//4==0 and year//100 != 0 :
print('输入的年份是{},并且为闰年'.format(year))
else:
print('输入的年份不是闰年,请重新输入!',end="\n")
except Exception as error:
print(error)
return year
# fun()
print(fun())
- 猴子吃桃问题(递归):
猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个。第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了,求第一天共摘了多少桃子?
'''2. 猴子吃桃问题(递归):
猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个。
第二天早上又将剩下的桃子吃掉一半,又多吃了一个。
以后每天早上都吃了前一天剩的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了,求第一天共摘了多少桃子?'''
def fun(n):
if n==10:
return 1
else:
return 2*(fun(n+1)+1)
print(fun(1))
总结
本文为学习笔记,转载请标明出处,本文仅供交流学习,请勿用于非法途径,希望本文对大家有帮助。
仅是个人意见,如有不足之处或者侵权,请留言