一、首先什么是函数?
如果在开发程序时,需要某块代码多次,但是为了提高编写的效率以及代码的重用,所以把具有独立功能的代码块组织为一个小模块,这就是函数。
* 函数的使用包含两个步骤:
1. 定义函数 —— 封装 独立的功能
2. 调用函数 —— 享受 封装 的成果
那么思考一个问题
---能否将 函数调用 放在 函数定义 的上方?
答案肯定不行!!!
1.* 因为在 使用函数名 调用函数之前,必须要保证 Python
已经知道函数的存在
2.* 否则控制台会提示 NameError: name 'say_hello' is not defined
(名称错误:say_hello 这个名字没有被定义)
二、函数的文档注释
- 在开发中,如果希望给函数添加注释,应该在 定义函数 的下方,使用 连续的三对引号
- 在 连续的三对引号 之间编写对函数的说明文字
- 在 函数调用 位置,使用快捷键 CTRL + Q 可以查看函数的说明信息
注意:因为 函数体相对比较独立,函数定义的上方,应该和其他代码(包括注释)保留 两个空行
三. 函数的参数
参数的作用
- 函数,把 具有独立功能的代码块 组织为一个小模块,在需要的时候 调用
- 函数的参数,增加函数的 通用性,针对 相同的数据处理逻辑,能够 适应更多的数据
- 在函数 内部,把参数当做 变量 使用,进行需要的数据处理
- 函数调用时,按照函数定义的参数顺序,把 希望在函数内部处理的数据,通过参数 传递
函数参数的使用
- 在函数名的后面的小括号内部填写 参数
- 多个参数之间使用 , 分隔
形参和实参
- 形参:定义 函数时,小括号中的参数,是用来接收参数用的,在函数内部 作为变量使用
- 实参:调用 函数时,小括号中的参数,是用来把数据传递到 函数内部 用的
缺省参数(函数参数的默认值)
在调用函数时,缺省参数的值如果没有传入,则被认为是默认值。
def printLine(a=5)
print(''a)
printLine(6)#如果传入6则等于6 如果不传入任何值,则为5
注意
缺省参数(即带有默认值的参数)一定要位于参数列表的最后面
不定长参数
有时可能需要一个函数能处理比当初声明时更多的参数。这些参数叫做不定长参数,声明时不会命名。
.基本语法如下:
def functionname([formal_args,]args,*kwargs):
'''函数_文档字符串'''
function_suite
return [expression]
加了星号()的变量args会存放所有为命名的变量参数,aegs为元组;而加 **的变量kwargs会存放命名参数,即形如key=value的参数,kwargs为字典。这种方式叫拆包
四、函数的返回值
- 在程序开发中,有时候,会希望 一个函数执行结束后,告诉调用者一个结果,以便调用者针对具体的结果做后续的处理
- 返回值 是函数 完成工作后,最后 给调用者的 一个结果
- 在函数中使用 return 关键字可以返回结果
- 调用函数一方,可以 使用变量 来 接收 函数的返回结果
注意:return 表示返回,后续的代码都不会被执行
>>>函数根据有没有参数,有没有返回值,可以相互组合,一共有4种
- 无参数,无返回值
- 无参数,又反悔
- 有参数,无返回值
- 有参数,有返回值
<1>无参数,无返回值的函数
此类函数,不能接收参数,也没有返回值,一般情况下,打印提示灯类似的功能,使用这类的函数
<2>无参数,有返回值的函数
此类函数,不能接收参数,但是可以返回某个数据,一般情况下,像采集数据,用此类函数
<3>有参数,无返回值的函数
此类函数,能接收参数,但不可以返回数据,一般情况下,对某些变量设置数据而不需结果时,用此类函数
<4>有参数,有返回值的函数
此类函数,不仅能接收参数,还可以返回某个数据,一般情况下,像数据处理并需要结果的应用,用此类函数
五、函数的嵌套调用
- 一个函数里面 又调用 了 另外一个函数,这就是 函数嵌套调用
- 如果函数 test2 中,调用了另外一个函数 test1
- 那么执行到调用 test1 函数时,会先把函数 test1 中的任务都执行完
- 才会回到 test2 中调用函数 test1 的位置,继续执行后续的代码
Python中函数参数是引用传递(注意不是值传递)。对于不可变类型,因变量不能修改,所以运算不会影响到变量自身;而对于可变类型来说,函数体中的运算有可能会更改传入的参数变量。
六、函数的局部变量和全局变量
局部变量
- 局部变量,就是函数内部定义的变量
- 不同的函数,可以定义相同的名字的局部变量,但是各用个的互不影响
- 局部变量的作用,为了临时保存数据需要在函数中定义变量来进行存储,这就是他的作用
在函数内部定义的普通变量值在该函数内起作用,当函数运行结束后,在其内部定义的局部变量将被自动删除而不可访问。在函数内部定义的全局变量当函数结束后仍然存在并且可以访问
全局变量
- 如果一个变量,既能在一个函数中使用,也能在其他函数中使用,这样的变量就是全局变量
#定义全局变量
a = 100
def test1():
print(a)
def test2():
print(a)
# 调用函数
test1()
test2()
修改全局变量
既然全局变量,就是能够在所以的函数中进行使用,那么可否进行修改呢?
1、在函数外边定义的变量叫做全局变量
2、全局变量能够在所有的函数中进行访问
4、如果在函数中修改全局变量,那么就需要使用global进行声明,否则出错
5、如果全局变量的名字和局部变量的名字相同,那么使用的是局部变量的,强龙不压地头蛇
1、在函数中不使用global声明全局变量时不能修改全局变量的本质是不能修改全局变量的指向,即不能将全局变量指向新的数据。
2、对于不可变类型的全局变量来说,因其指向的数据不能修改,所以不使用global时无法修改全局变量。
3、对于可变类型的全局变量来说,因其指向的数据可以修改,所以不使用global时也可修改全局变量。
七、递归函数
如果一个函数在内部不调用其他的函数,而是自己本身的话,这个函数就是递归函数
举个栗子
* 我们来计算阶乘 5! = 12345
八、匿名函数
- 用lambda关键词能创建小型匿名函数。这种函数得名于省略了用def声明函数的标准步骤。
lambda函数的语法只包含一个语句,如下:
lambda [arg1 [,arg2,.....argn]]:expression
例如:
sum = lambda arg1, arg2: arg1 + arg2
#调用sum函数
print "Value of total : ", sum( 10, 20 )
print "Value of total : ", sum( 20, 20 )
Lambda函数能接收任何数量的参数但只能返回一个表达式的值
匿名函数不能直接调用print,因为lambda需要一个表达式