这篇文章介绍python中函数的基本知识。
在任何编程语言中,函数的作用都是相同的,它可以将一些需要重复执行的语句组合起来,方便在需要的时候调用他们,python中使用def关键字来创建一个函数,请看下面的实例:
#!/usr/bin/env python3
#coding=utf-8
dect={"one":1,"two":2,"three":3}
#创建函数,函数名为in_dect,中括号中为空代表不接收传入参数,函数执行过程中遇到return会结束执行,将return后的值返回给调用者
#------
def in_dect():
"""根据字典传入键返回值"""
try:
count=dect[num]
except KeyError as err:
count=0
return count
#------
#将num设置成dect字典中不同的键,在print中调用刚才创建的函数,in_dect()函数会根据num键返回对应的值,如果传入的键不存在,则触发KeyError异常,返回0
num="one"
print(in_dect())
num="two"
print(in_dect())
num="xxx"
print(in_dect())
#程序输出
1
2
0
我们可以使用"三引号"给每个函数添加一段功能说明,在python中,通过"函数名.__doc__"能够打印出这段说明文字,请看下面的实例:
#!/usr/bin/env python3
#coding=utf-8
#------
def sayhello():
"""打印出hello world"""
"""www.qingsword.com"""
print("hello world!")
#------
sayhello() #直接调用函数
print(sayhello.__doc__) #打印出函数中的说明信息
#程序输出
hello world!
打印出hello world
#注意上面的输出,__doc__只能够打印出函数中第一个"三引号"所包含的说明信息
函数中的变量名称和全局中的变量名称可以相同,函数的变量名称只作用与函数内部,请看下面的实例:
#!/usr/bin/env python3 #coding=utf-8 #------ def re_list(): lst=[1,2,3] return lst #------ lst=["a","b","c"] print(lst,re_list()) #在上面的程序中,re_list()函数中包含了一个变量名称lst,全局中也有一个相同名称的变量,但两者互不干扰,函数中的变量的作用域仅限函数本身,当函数被调用时创建,函数执行完成后被回收,下面是程序输出 ['a', 'b', 'c'] [1, 2, 3]
可以在自定义的函数括号中定义变量来接收传入数据,请看下面的实例:
#!/usr/bin/env python3
#coding=utf-8
#------
def re_dect_value(dect,k):
return dect[k]
#------
d={"a":1,"b":2,"c":3}
k="a"
#调用函数时,将d和k传递给函数,函数定义时,括号中包含了两个参数,这相当于将函数参数中的dect指向了d所引用的内存区域的数据(列表数据),k同理,所以这个函数的return语句返回的值,实际上就等价与d[k]
print(re_dect_value(d,k))
#程序输出:
1
可以使用判断语句来判断传递给函数的参数的数据类型,通过数据类型判断调用不同的函数区块执行,如果不携带参数,则使用默认值所指向的区块执行,请看下面的实例:
#!/usr/bin/env python3
#coding=utf-8
#choose_def函数,用于确定传入的数据是哪种类型,根据不同类型调用不同函数执行,如果不传入参数,则使用默认值(即typ="default",idx=0)
def choose_def(typ="default",idx=0):
if type(typ)==type([]):
print(c_dect(typ,idx))
elif type(typ)==type(""):
print(c_str(typ,idx))
#------
def c_dect(d,idx):
return d[idx]
#------
def c_str(s,idx):
return s[idx]
#------
lst=[1,2,3,4]
s="www.qingsword.com"
i=2
choose_def(lst,i)
choose_def(s,i)
choose_def()
#程序输出
3
w
d
#在上面的程序中,最后一次调用选择函数时没有携带参数,python会使用定义函数时设定的默认值(如果有),程序判断出"default"是一个字符串,所以调用字符串函数c_str(),因为默认的idx是0,所以打印出"default"第一个字符d
除了使用类型判断外,还可以使用字符串判断,通过每个类型判断所返回的字符串,来判断传入的参数属于那种类型,对上面的程序中的choose_def函数做出一点点修改,执行结果相同:
#将type()判断后返回的值转化成字符串,与对应的字符串值比较 def choose_def(typ="default",idx=0): if str(type(typ))=="<class 'list'>": print(c_dect(typ,idx)) elif str(type(typ))=="<class 'str'>": print(c_str(typ,idx))
当传递了一个错误的数据给函数时,除了使用try捕获异常外,还能够使用raise关键字来主动抛出异常,修改choose_def()函数,在末尾添加下面的语句:
def choose_def(typ="default",idx=0):
if str(type(typ))=="<class 'list'>":
print(c_dect(typ,idx))
elif str(type(typ))=="<class 'str'>":
print(c_str(typ,idx))
else:
raise TypeError("错误的参数:%s"%typ)
#向函数传递一个错误的参数,整数
choose_def(123)
#当程序执行if判断时发现没有类型能够匹配传入的整型,所以跳转到else执行下面的raise语句,当raise语句被执行时,会立刻终止程序的执行,并抛出一个异常,这个异常是我们主动抛出的,下面是这个异常的显示信息,其中的中文内容是我们自定义的
builtins.TypeError: 错误的参数:123
最后再来看一个实例,创建一个函数,接受两个数值,返回这两个数值相加后的结果:
#!/usr/bin/env python3
#coding=utf-8
#------如果输入的字符不是数值,if判断会匹配到else从而主动抛出一个异常
def a_plus(x,y):
"""返回x+y的值"""
if is_Num(x)!=False and is_Num(y)!=False:
return float(x)+float(y)
else:
raise TypeError("输入的数值错误:%s,%s"%(x,y))
#------用来判断输入的是否为数值数据,不论是浮点数,整数或科学计数法,使用float()转换时都不会报错,而其他的字符就会引发ValueError异常返回False,如果不报错,返回True
def is_Num(x):
"""判断键盘输入的是否为数字"""
try:
float(x)
except ValueError:
return False
else:
return True
#------
x=input("第一个数:")
y=input("第二个数:")
print("相加结果:%.2f"%a_plus(x, y))
#程序输出
第一个数:1.2
第二个数:1.3333
相加结果:2.53
第一个数:abc
第二个数:111
builtins.TypeError: 输入的数值错误:abc,111