主要内容
1.函数基本语法及特性
2.参数与局部变
3.返回值 4.递归
5.名函数 6.函数式编程介绍
7.阶函数 8.内置函数
函数基本语法及特性
定义
数学函数定义:一般的,在一个变化过程中,如果有两个变量x和y,并且对于x的每一 个确定的值,y都有唯一确定的值与其对应,那么我们就把x称为自变量,把y称为因变 量,y是x的函数。自变量x的取值范围叫做这个函数的定义域。
但编程中的「函数」概念,与数学中的函数是有很 同的 函数是逻辑结构化和过程化的一种编程方法
函数的优点
减少重复代码
使程序变的可扩展
使程序变得易维护
函数与过程
定义函数
def fun1(): #函数名称
"The function decription" print("in the func1") return 0 #返回值
定义过程
1
2
3
|
def fun2():
"The progress decription"
print ( "in the func2" )
|
函数与过程 过程就是没有返回值的函数 但是在python中,过程会隐式默认返回none,所以在python中即便是过程也可以算作函数。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
def fun1():
"The function decription"
print ( "in the func1" )
return 0
def fun2():
"The progress decription"
print ( "in the func2" )
x = fun1()
y = fun2()
print ( "from func1 return is %s" % x)
print ( "from func2 return is %s" % y)
|
结果为:
1
2
3
4
|
in the func1
in the func2
from func1 return is 0
from func2 return is None
|
返回值
要想获取函数的执 结果,就可以 return语 把结果返回。
函数在执 过程中只要遇到return语 ,就会停 执 并返回结果,所以也可以 解为 return 语 代表着函数的结束,如果未在函数中指定return,那这个函数的返回值为None。
接受返回值
赋予变量,例如:
1
2
3
4
|
def test():
print ( 'in the test' )
return 0
x = test()
|
返回什么样的变量值
return 个数没有固定,return的类型没有固定。 例如:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
def test1():
print ( 'in the test1' )
def test2():
print ( 'in the test2' )
return 0
def test3():
print ( 'in the test3' )
return 1 , 'hello' ,[ 'alex' , 'wupeiqi' ],{ 'name' : 'alex' }
def test4():
print ( 'in the test4' )
return test2
x = test1()
y = test2()
z = test3()
u = test4()
print (x)
print (y)
print (z)
print (u)
|
结果是:
in the test1
in the test2
in the test3
in the test4
None
0
(1, 'hello', ['alex', 'wupeiqi'], {'name': 'alex'})
<function test2 at 0x102439488>
返回值数=0:返回None 没有return
返回值数=1:返回object return一个值,python 基本所有的数据类型都是对象。
返回值数>1:返回tuple, return多个值。
返回可以返回函数:return test2会将test2的内存地址返回。
为什么要有返回值?
想要整个函数执行的结果。 可能对执行结果进行相关操作。 比如登陆,返回true 接下来就可以进行其他操作。 如果是false 则不给操作。
函数参数
形参和实参定义
形参
形式参数,不是实际存在,是虚拟变量。在定义函数和函数体的时候使用形参,目的是在函数调用时接收实参(形参个数,类型应与实参一一对应)。
变量只有在被调时才分配内存单元
实参
实际参数,调用函数时传给函数的参数,可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以 把这些值传送给形参。因此应预先用赋值,输入 等办法使参数获得确定值。
区别
形参是虚拟的,不占用内存空间.形参变量只有在被调用时才分配内存单元,,在调用结束时,即刻释放所分配的内存单元。因此,形参只在函数内部有效。函数调用结束返回主调函数后,则不能再使该形参变量。
实参是一个变量,占用内存空间,数据传送单向,实参传给形参,不能形参传给实参。
1
2
3
4
5
6
7
8
9
10
|
def calc(x,y): #x,y为形参
res = x * * y
return res
c = calc(a,b) #a,b为实参
print (c)
def test(x,y): #x,y为形参
print (x)
print (y)
x = 1 #x为实参
y = 2 #y为实参
|
test(x=x,y=y) #等号左边x,y为形参,等号右边x,y为实参,引用不分顺序,按关键字引用。
默认参数
定义函数的时候,还可以有默认参数。 函数的默认参数的作用是简化调用,你只需要把必须的参数传进去。但是在需要的时候,又可以传入额外的参数来覆盖默认参数值。
1
2
3
4
5
6
7
8
9
|
#定义一个计算 x 的N次方的函数,默认是2次方
def test6(x,n = 2 ):
s = 1
while n> 0 :
n = n - 1
s = s * x
print (s)
return s
test6( 2 )
|
默认参数只能定义在必需参数的后面.
可变参数
如果想让一个函数能接受任意个参数,我们就可以定义一个可变参数:
def fn(*args):
print args
可变参数的名字前面有个 * 号,我们可以传入0个、1个或多个参数给可变参数: Python解释器会把传入的一组参数组装成一个tuple传递给可变参数,因此,在函数内部,直接把变量 args 看成一个 tuple 就好了。
定义可变参数的目的也是为了简化调用。假设我们要计算任意个数的平均值,就可以定义一个可变参数:
def average(*args):
...
这样,在调用的时候,可以这样写:
>>> average()
0
>>> average(1, 2)
1.5
>>> average(1, 2, 2, 3, 4)
2.4
位置参数和关键字
位置参数调用:实参与形参位置一一对应; 关键参数调用:位置无需固定。
正常情况下,给函数传参数要按顺序,如果不按顺序就可以用关键参数调用,只需指定参数名即可,但关键参数必须放在位置参数之后。
1
2
3
4
5
|
def test5(u,v,w):
print (u)
print (v)
print (w)
test5( 3 ,w = 2 ,v = 6 )
|
函数调用
Python内置了很多有用的函数,我们可以直接调用。
要调用一个函数,需要知道函数的名称和参数,比如求绝对值的函数 abs,它接收一个参数。
调用 abs 函数:
>>> abs(-21)
21
调用函数的时候,如果传入的参数数量不对,会报TypeError的错误,并且Python会明确地告诉你:abs()有且仅有1个参数,但给出了两个:
>>> abs(21,8)
Traceback (most recent call last):
File "/Users/cathy/PycharmProjects/p51cto/day3/func_test3.py", line 67, in <module>
abs(21,8)
TypeError: abs() takes exactly one argument (2 given)
如果传入的参数数量是对的,但参数类型不能被函数所接受,也会报TypeError的错误,并且给出错误信息:str是错误的参数类型:
>>> abs('a')
Traceback (most recent call last):
File "/Users/cathy/PycharmProjects/p51cto/day3/func_test3.py", line 69, in <module>
abs('a')
TypeError: bad operand type for abs(): 'str'
递归函数
在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。
举个例子,我们来计算阶乘 n! = 1 * 2 * 3 * ... * n,用函数 fact(n)表示:
1
2
3
4
|
def fact(n):
if n = = 1 :
return 1
return n * fact(n - 1 )
|
递归函数的优点是定义简单,逻辑清晰。理论上,所有的递归函数都可以写成循环的方式,但循环的逻辑不如递归清晰。
嵌套函数
python允许在定义函数的时候,其函数体内又包含另外一个函数的完整定义。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
name = "test1"
def changeout():
name = "test2"
def changeinner():
name = "test3"
print ( "changeinner赋值打印" , name)
changeinner() # 调用内层函数
print ( "外层调用内层打印" , name)
changeout()
print ( "调用外层打印" , name)
|
内部函数可以访问其外部函数的作用域,但是外部函数不能访问内部函数的作用域。
def change1(name):
匿名函数
匿名函数就是不需要显式的指定函数
#这段代码 def calc(n): return n**n print(calc(10))
#换成匿名函数 calc = lambda n:n**n print(calc(10))
函数式编程
单说,"函数式编程"是一种"编程范式"(programming paradigm),也就是如何编写程序的方法论。
主要思想是把运算过程尽量写成一系列嵌套的函数调用。
参考页面
http://www.cnblogs.com/alex3714/articles/5740985.html
http://www.imooc.com/code/3516
http://blog.csdn.net/suncherrydream/article/details/51682560
http://www.zzvips.com/article/85512.html
原文链接:http://www.cnblogs.com/cathywu/p/7209146.html