Python编程入门指南之函数

Python编程:函数

函数是带名字的代码块,用于完成具体的工作。要执行函数定义的特定任务,可调用该函数。需要在程序中多次执行同一项任务时,你无需反复编写完成该任务的代码,而只需调用执行该任务的函数,让 Python 运行其中的代码。函数可以极大地简化代码编写与让代码结构清晰化。

定义和调用函数

>>>def greeting():
>>>  """简单问候"""
>>>  print("Hello!")

关键字 def 来告诉 Python 你要定义一个函数,后面紧跟函数名。在括号内指出函数为完成其任务需要什么样的信息。紧跟在 def greet_user(): 后面的所有缩进行构成了函数体。三引号(""" “”")内的文本是被称为**文档字符串( docstring )**的注释,描述了函数是做什么的,Python 使用它们来生成有关程序中函数的文档。

>>>greeting()
Hello!

调用函数,可依次指定函数名以及用括号括起的必要信息。

向函数传递信息

如果我们在打招呼时,需要用户的名字用作抬头。为此,可在函数定义 def greet_user() 的括号内添加 username。

>>>def greeting(username):
>>>  """简单问候用户"""
>>>  print("Hello,"+username.title()+"!")
greeting("jessi")
Hello,Jessi!

在函数greet_user() 的定义中,变量 username 是一个 形参 —— 函数完成其工作所需的一项信息。在代码 greet_user(‘jesse’) 中,值 ‘jesse’ 是一个 实参——调用函数时传递给函数的信息。将实参传递给函数并存储在形参中。

传递实参:位置实参

你调用函数时, Python 必须将函数调用中的每个实参都关联到函数定义中的一个形参。

最简单的关联方式是基于实参的顺序,这种关联方式被称为位置实参。此时调用函数时实参的位置十分重要,需要与形参对应,不然会引发逻辑错误

>>>def describe_pet(animal_type, pet_name):
>>>""" 显示宠物的信息 """
>>>print("My " + animal_type + "'s name is " + pet_name.title() + ".")

>>>describe_pet('hamster', 'harry')
My hamster's name is Harry.

传递实参:关键字实参

关键字实参是传递给函数值时,直接在实参中将名称和值关联起来。此时实参的位置不再重要,形参所对应的值已经明示了。

describe_pet(animal_type='hamster', pet_name='harry')

传递实参:默认值

编写函数时,可给每个形参指定 默认值 。在调用函数中给形参提供了实参时, Python 将使用指定的实参值,否则,将使用形参的默认值。默认值必须放在形参最后。

>>>def describe_pet(pet_name, animal_type='dog'):
   -snip-
>>>describe_pet(pet_name='willie')

你提供的实参多于或少于函数完成其工作所需的信息时,将出现实参不匹配错误。

传递列表

将列表传递给函数可以提升列表处理的效率。比如将用户姓名列表 username 传递给 greeting() 函数可以生成批量打招呼的输出。

def greeting(usernames):
"""给用户打招呼"""
	for name in usernames:
    print("Hello, " + name.title() + "!")

禁止函数修改列表

有了传递列表的功能我们就可以批量修改列表中的数据。有时候,我们需要获取列表中的数据而保持原始列表不变,此时就要使用切片表示法禁止修改列表。此时函数处理的是列表的副本,而原始列表不变。

function_name(list_name[:]) 

传递任意数量实参

当顾客要点一个pizza,我们不知道ta要点多少种配料,就可以写成如下形式:

>>>def make_pizza(*toppings):
>>>    -snip-

形参名 *toppings 中的星号让 Python 创建一个名为 toppings 的空元组,并将收到的所有值都封装到这个元组中。

结合使用位置实参和任意数量实参

如果顾客要点一个pizza并且告知它的尺寸和配料:

>>>def make_pizza(size, *toppings):
>>> 	-snip

使用任意数量的关键字实参

有时候,需要接受任意数量的实参,但预先不知道传递给函数的会是什么样的信息。在这种情况下,可使用字典接收输入的实参。

>>>def build_profile(**user_info):
	"""创建字典存储用户信息"""
    profile{}
    for key,value in user_info.items():
      profile[key]=value
    return profile
>>>user_profile=build_profile(local='London',field='physics')
>>>print(user_profile)
{'local':'London','field':'physics'}

形参 **user_info 中的两个星号让 Python 创建一个名为 user_info 的空字典,并将收到的所有键值对都封装到这个字典中。

返回值

函数并非总是直接显示输出,相反,它可以处理一些数据,并返回一个或一组值。函数返回的值被称为返回值 。

可使用return返回调用函数的代码行。返回值让你能够将程序的大部分繁重工作移到函数中去完成,从而简化主程序。

返回简单值

可将输出完整姓名提出来作为一个函数模块,此时主程序只有两行:

>>>def get_formatted_name(first_name, middle_name, last_name):
>>>""" 返回整洁的姓名 """
>>>	full_name = first_name + ' ' + middle_name + ' ' + last_name
>>>	return full_name.title()

>>>musician = get_formatted_name('john', 'lee', 'hooker')
>>>print(musician)
John Lee Hooker

让实参可选

有时候,需要让实参变成可选的,这样使用函数的人就只需在必要时才提供额外的信息。

例如,有些人的名字有中间名,有些人没有,我们就可以给实参 middle_name 指定一个默认值 —— 空字符串,
并将其移到形参列表的末尾:

>>>def get_formatted_name(first_name, last_name, middle_name=''):
    """返回整洁姓名"""
>>>	  if middle_name:
>>> 	full_name = first_name + ' ' + middle_name + ' ' + last_name
>>>   else:
>>>		full_name = first_name + ' ' + last_name
>>>   return full_name

返回字典

函数可返回任何类型的值,包括列表和字典等较复杂的数据结构。

>>>def build_person(first_name,last_name):
  """返回包含人物信息的字典"""
>>>   person={'first':first_name,'last':last_name}
>>>   return person

将函数存储在模块中

函数的优点之一是,使用它们可将代码块与主程序分离。我们可以更进一步将函数存储在模块中,在主程序中导入模块。

导入整个模块

模块是扩展名为 .py 的文件,包含要导入到程序中的代码。

import pizza

代码行 import pizza 让 Python 打开文件 pizza.py ,并将其中的所有函数都复制到这个程序中。调用模块中的函数用句点法:

module_name.function_name()

导入特定函数

如果你不需要模块中的所有函数,只需要其中某个特定函数:

from module_name import function_name
from module_name import function_name  #导入模块中某几个函数

使用as给函数指定别名

如果要导入的函数的名称可能与程序中现有的名称冲突,或者函数的名称太长,可指定简短而独一无二的 别名 —— 函数的另一个名称,类似于外号。

from pizza import make_pizza as mp  #将函数make_pizza()重新命名为mp()

使用as给模块指定别名

你还可以给模块指定别名。这样不仅能使代码更简洁,还可以让你不再关注模块名,而专注于描述性的函数名。这些函数名明确地指出了函数的功能,对理解代码而言,它们比模块名更重要。

import module_name as mn

导入模块中的所有函数

from module_name import * 

import 语句中的 * 让 Python 将模块 pizza 中的每个函数都复制到这个程序文件中。由于导入了每个函数,可通过名称来调用每个函数,而无需使用句点表示法。

然而,最好不要采用这种导入方法:如果模块中有函数的名称与你的项目中使用的名称相同,可能导致意想不到的结果: Python 可能遇到多个名称相同的函数或变量,进而覆盖函数,而不是分别导入所有的函数。

函数编写指南

1.应给函数指定描述性名称,且只在其中使用小写字母和下划线

2.每个函数都应包含简要地阐述其功能的注释,该注释应紧跟在函数定义后面,并采用文档字符串格式

3.给形参指定默认值时与使用关键字实参时,等号两边不要有空格

4.如果程序或模块包含多个函数,可使用两个空行将相邻的函数分开

5.所有的 import 语句都应放在文件开头,唯一例外的情形是,在文件开头使用了注释来描述整个程序

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

您可能也感兴趣:

为您推荐

Python编程入门指南之函数

Python编程入门指南之函数

[db:摘要]...

2022-12-26 栏目:编程控

当前非电脑浏览器正常宽度,请使用移动设备访问本站!