函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。
函数能提高应用的模块性,和代码的重复利用率。你已经知道Python提供了许多内建函数,比如print()。但你也可以自己创建函数,这被叫做用户自定义函数。
你可以定义一个由自己想要功能的函数,以下是简单的规则:
Python 定义函数使用 def 关键字,一般格式如下:
def 函数名(参数列表): |
函数体 |
默认情况下,参数值和参数名称是按函数声明中定义的的顺序匹配起来的。
让我们使用函数来输出"Hello World!":
更复杂点的应用,函数中带上参数变量:#!/usr/bin/python3 |
# 计算面积函数 |
def area(width, height): |
return width * height |
def print_welcome(name): |
print("Welcome", name) |
print_welcome("Web3") |
w = 4 |
h = 5 |
print("width =", w, " height =", h, " area =", area(w, h)) |
定义一个函数:给了函数一个名称,指定了函数里包含的参数,和代码块结构。
这个函数的基本结构完成以后,你可以通过另一个函数调用执行,也可以直接从 Python 命令提示符执行。
如下实例调用了printme()函数:
以上实例输出结果:
我要调用用户自定义函数! |
再次调用同一函数 |
在 Python 中,所有参数(变量)都是按引用传递。如果你在函数里修改了参数,那么在调用这个函数的函数里,原始的参数也被改变了。例如:
函数内取值: [10, 20, 30, [1, 2, 3, 4]] |
函数外取值: [10, 20, 30, [1, 2, 3, 4]] |
以下是调用函数时可使用的正式参数类型:
必需参数须以正确的顺序传入函数。调用时的数量必须和声明时的一样。
调用printme()函数,你必须传入一个参数,不然会出现语法错误:
关键字参数
关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值。
使用关键字参数允许函数调用时参数的顺序与声明时不一致,因为 Python 解释器能够用参数名匹配参数值。
以下实例在函数 printme() 调用时使用参数名:
芝麻教程
以下实例中演示了函数参数的使用不需要使用指定顺序:
名字: Web3 |
年龄: 50 |
调用函数时,如果没有传递参数,则会使用默认参数。以下实例中如果没有传入 age 参数,则使用默认值:
以上实例输出结果:
名字: Web3 |
年龄: 50 |
------------------------ |
名字: Web3 |
年龄: 35 |
你可能需要一个函数能处理比当初声明时更多的参数。这些参数叫做不定长参数,和上述2种参数不同,声明时不会命名。基本语法如下:
def functionname([formal_args,] *var_args_tuple ): |
"函数_文档字符串" |
function_suite |
return [expression] |
加了星号(*)的变量名会存放所有未命名的变量参数。如果在函数调用时没有指定参数,它就是一个空元组。我们也可以不向函数传递未命名的变量。如下实例:
输出: |
10 |
输出: |
70 |
60 |
50 |
python 使用 lambda 来创建匿名函数。
所谓匿名,意即不再使用 def 语句这样标准的形式定义一个函数。
语法
lambda 函数的语法只包含一个语句,如下:
lambda [arg1 [,arg2,.....argn]]:expression |
相加后的值为 : 30 |
相加后的值为 : 40 |
return [表达式] 语句用于退出函数,选择性地向调用方返回一个表达式。不带参数值的return语句返回None。之前的例子都没有示范如何返回数值,以下实例演示了 return 语句的用法:
以上实例输出结果:
函数内 : 30 |
函数外 : 30 |
Pyhton 中,程序的变量并不是在哪个位置都可以访问的,访问权限决定于这个变量是在哪里赋值的。
定义在函数内部的变量拥有一个局部作用域,定义在函数外的拥有全局作用域。
局部变量只能在其被声明的函数内部访问,而全局变量可以在整个程序范围内访问。调用函数时,所有在函数内声明的变量名称都将被加入到作用域中。如下实例:
以上实例输出结果:
函数内是局部变量 : 30 |
函数外是全局变量 : 0 |