• 返回值就是函数执行以后返回的结果 • 通过return来指定函数的返回值 • return后面可以跟任意对象,返回值甚至可以是一个函数
• help()是Python中内置函数,通过help()函数可以查询Python中函数的用法 • 在定义函数时,可以在函数内部编写文档字符串,文档字符串就是对函数的说明
• 作用域(scope) • 作用域指的是变量生效的区域 • 在Python中一共有两种作用域
a=1 b=1 c=1 scope=locals() def fn(): a=1 b=1 c=1 scope=locals() fn()• 全局作用域 • 全局作用域在程序执行时创建,在程序执行结束时销毁 • 所有函数以外的区域都是全局作用域 • 在全局作用域中定义的变量,都是全局变量,全局变量可以在程序的任意位置进行访问
a=1 b=1 c=1 scope=locals() def fn(): a=1 b=1 c=1 scope=globals() scope['e']=5 fn()• 函数作用域 • 函数作用域在函数调用时创建,在调用结束时销毁 • 函数每调用一次就会产生一个新的函数作用域 • 在函数作用域中定义的变量,都是局部变量,它只能在函数内部被访问
• 命名空间实际上就是一个字典,是一个专门用来存储变量的字典 • locals()用来获取当前作用域的命名空间 • 如果在全局作用域中调用locals()则获取全局命名空间,如果在函数作用域中调用locals()则获取函数命名空间 • 返回值是一个字典
• 递归是解决问题的一种方式,它的整体思想,是将一个大问题分解为一个个的小问题,直到问题无法分解时,在去解决问题 • 递归式函数有2个条件 • 1. 基线条件 问题可以被分解为最小问题,当满足基线条件时,递归就不执行了 • 2. 递归条件 可以将问题继续分解的条件
代码练习:
用函数实现一个判断用户输入的年份是否是闰年的程序 1.能被400整除的年份 2.能被4整除,但是不能被100整除的年份 以上2种方法满足一种即为闰年 def test_year(year): if year%400==0: print("%s年是润年"%year) elif year%4==0 and year%100!=0: print("%s年是润年" % year) else: print("%s年是不润年" % year) year1=int(input("请输入一个年份:")) test_year(year1) 猴子吃桃问题(递归): 猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个。第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了,求第一天共摘了多少桃子? peach_number=1 i=1 def eat_peach(peach_number,i): m = 10 - i r = (m, peach_number) print("第%s天猴子吃完桃子后,剩下%s个桃子" % r) peach_number = 2*(peach_number+1) if i==9: print("猴子总共摘了%s个桃子" %peach_number) else: return eat_peach(peach_number,i+1) eat_peach(peach_number,i)运行结果:
第9天猴子吃完桃子后,剩下1个桃子 第8天猴子吃完桃子后,剩下4个桃子 第7天猴子吃完桃子后,剩下10个桃子 第6天猴子吃完桃子后,剩下22个桃子 第5天猴子吃完桃子后,剩下46个桃子 第4天猴子吃完桃子后,剩下94个桃子 第3天猴子吃完桃子后,剩下190个桃子 第2天猴子吃完桃子后,剩下382个桃子 第1天猴子吃完桃子后,剩下766个桃子 猴子总共摘了1534个桃子