函数的使用是为了封装需要频繁使用的代码,避免重复编写。

一、函数的定义格式

def 函数名(参数):

    函数代码

二、函数的参数

1、普通参数

函数取得的参数是你提供给函数的值,这样函数就可以利用这些值 做 一些事情。这些参数就像变量一样,只不过它们的值是在我们调用函数的时候定义的,而非在函数本身内赋值。

函数中的参数名称为形参 而提供给函数调用的值称为实参。 

#!/usr/bin/env python

def printmax(a,b): #定义一个函数printmax(a,b),括号中的a和b为形参。

if a > b:

print a,'is max'

else:

print b,'is max'

printmax(5,4)

x = 51

y = 10

printmax(x,y) #括号中的x,y为实参,实参x的值赋给形参a,实参y的值赋给形参b

执行结果 

5 is max

51 is max

2、默认参数

对于一些函数,你可能希望它的一些参数是 可选 的,如果用户不想要为这些参数提供值的话,这些参数就使用默认值。

只有在形参表末尾的那些参数可以有默认参数值,即你不能在声明函数形参的时候,先声明有默认值的形参而后声明没有默认值的形参。

#!/usr/bin/env python

def say(message,time = 1): #定义time的默认值是1

print message * time

say('Hello')

say('World',2)

执行结果

Hello

WorldWorld

3、动态参数

当要使函数接收元组或字典形式的参数的时候,有一种特殊的方法,它分别使用*和**前缀。这种方法在函数需要获取可变数量的参数的时候特别有用。

def func(*arg): 参数的值可以是任意个(单值或元组或列表)。默认会把所有的参数组成一个元组,如果参数本身就是一个序列(元组或列表),可以使用加*号的方式来避免内部构造元组。

>>> def fun(*arg):

...     print arg

>>> fun(1,2,3)

(1, 2, 3)

>>> li=(1,2,3)

>>> fun(li) #传入参数是一个元组

((1, 2, 3),) #传入的整个元组参数变成新元组的一个元素

>>> fun(*li) #加*号

(1, 2, 3) #传入的元组参数不重构

def func2(**arg): 参数的值可以是任意个(格式必须都为key=value)。默认会把所有的参数组成一个字典,如果参数本身就是一个字典,可以使用加**号的方式来避免内部构造元组。

fun2(k1=123,k2=234)

{'k2': 234, 'k1': 123}

>>> dic={'k2': 234, 'k1': 123}

>>> fun2(**dic)

{'k2': 234, 'k1': 123}

def func(*args,**kwargs): 参数可以混用,表示可以接受单值、元组、列表、字典格式的参数。

三、lambda表达式

lambda表达式是一个简单的函数速写,实现简单的逻辑,并且自动return结果。

func = lambda arg1,arg2:arg1+arg2

等于

def func(arg1,arg2):

return arg1+arg2

四、内置函数

map(): 遍历序列,对序列中每个元素进行操作,最终获取新的序列

例:两个列表元素相加

>>> l=[1,2,3]

>>> l2=[4,5,6]

>>> func=lambda a1,a2:a1+a2

>>> map(func,l,l2)

[5, 7, 9]

filter(): 对于序列中的元素进行筛选,最终获取符合条件的序列

>>> li=[11,22,33]

>>> print filter(lambda a:a>11,li)

[22, 33]

reduce(): 对序列中的元素进行累计操作。最终获取新的序列

>>> li=[11,22,33]

>>> print reduce(lambda a1,a2:a1+a2,li)

66