Python 函数

函数是一种仅在调用时运行的代码块。

可以将数据(称为参数)传递到函数中。

函数可以把数据作为结果返回。


创建函数

在 Python 中,使用 def 关键字定义函数:

  1. def my_function():
  2. print("Hello from a function")

调用函数

如需调用函数,请使用函数名称后跟括号:

  1. def my_function():
  2. print("Hello from a function")
  3. my_function()

参数

信息可以作为参数传递给函数。

参数在函数名后的括号内指定。您可以根据需要添加任意数量的参数,只需用逗号分隔即可。

下面的例子有一个带参数(fname)的函数。当调用此函数时,我们传递一个名字,在函数内部使用它来打印全名:

  1. def my_function(fname):
  2. print(fname + " Gates")
  3. my_function("Rory John")
  4. my_function("Jennifer Katharine")
  5. my_function("Phoebe Adele")

默认参数值

下面的例子展示如何使用默认参数值。

如果我们调用了不带参数的函数,则使用默认值:

  1. def my_function(country = "China"):
  2. print("I am from " + country)
  3. my_function("Sweden")
  4. my_function("India")
  5. my_function()
  6. my_function("Brazil")

以 List 传参

发送到函数的参数可以是任何数据类型(字符串、数字、列表、字典等),并且在函数内其将被视为相同数据类型。

例如,如果您将 List 作为参数发送,它到达函数时仍将是 List(列表):

  1. def my_function(food):
  2. for x in food:
  3. print(x)
  4. fruits = ["apple", "banana", "cherry"]
  5. my_function(fruits)

返回值

如需使函数返回值,请使用 return 语句:

  1. def my_function(x):
  2. return 5 * x
  3. print(my_function(3))
  4. print(my_function(5))
  5. print(my_function(9))

关键字参数

还可以使用 key = value 语法发送参数。

参数的顺序无关紧要。

  1. def my_function(child3, child2, child1):
  2. print("The youngest child is " + child3)
  3. my_function(child1 = "Phoebe", child2 = "Jennifer", child3 = "Rory")

在 Python 文档中,“关键字参数”一词通常简称为 kwargs。


任意参数

如果您不知道将传递给您的函数多少个参数,请在函数定义的参数名称前添加 *。

这样,函数将接收一个参数元组,并可以相应地访问各项:

如果参数数目未知,请在参数名称前添加 *:

  1. def my_function(*kids):
  2. print("The youngest child is " + kids[2])
  3. my_function("Phoebe", "Jennifer", "Rory")

pass 语句

函数定义不能为空,但是如果您出于某种原因写了无内容的函数定义,请使用 pass 语句来避免错误。

  1. def myfunction:
  2. pass

递归

Python 也接受函数递归,这意味着定义的函数能够调用自身。

递归是一种常见的数学和编程概念。它意味着函数调用自身。这样做的好处是可以循环访问数据以达成结果。

开发人员应该非常小心递归,因为它可以很容易地编写一个永不终止的,或者使用过量内存或处理器能力的函数。但是,在被正确编写后,递归可能是一种非常有效且数学上优雅的编程方法。

在这个例子中,tri_recursion() 是我们定义为调用自身 ("recurse") 的函数。我们使用 k 变量作为数据,每次递归时递减(-1)。当条件不大于 0 时(比如当它为 0 时),递归结束。

对于新的开发人员来说,可能需要一些时间来搞清楚其工作原理,最好的方法是测试并修改它。

下面是一个递归的例子:

  1. def tri_recursion(k):
  2. if(k>0):
  3. result = k+tri_recursion(k-1)
  4. print(result)
  5. else:
  6. result = 0
  7. return result
  8. print("\n\nRecursion Example Results")
  9. tri_recursion(6)