8.2.3 默认值
编写函数时,可给每个形参指定默认值。在调用函数中给形参提供了实参时,Python将使用 指定的实参值;否则,将使用形参的默认值。因此,给形参指定默认值后,可在函数调用中省略 相应的实参。使用默认值可简化函数调用,还可清楚地指出函数的典型用法。
例如,如果你发现调用describe_pet()时,描述的大都是小狗,就可将形参animal_type的默 认值设置为'dog'。这样,调用describe_pet()来描述小狗时,就可不提供这种信息:
def describe_pet(pet_name, animal_type='dog'): """显示宠物的信息""" print("\nI have a " + animal_type + ".") print("My " + animal_type + "'s name is " + pet_name.title() + ".") describe_pet(pet_name='willie')
这里修改了函数describe_pet()的定义,在其中给形参animal_type指定了默认值'dog'。这 样,调用这个函数时,如果没有给animal_type指定值,Python将把这个形参设置为'dog':
I have a dog. My dog's name is Willie.
请注意,在这个函数的定义中,修改了形参的排列顺序。由于给animal_type指定了默认值, 无需通过实参来指定动物类型,因此在函数调用中只包含一个实参——宠物的名字。然而,Python 依然将这个实参视为位置实参,因此如果函数调用中只包含宠物的名字,这个实参将关联到函数 定义中的第一个形参。这就是需要将pet_name放在形参列表开头的原因所在。 现在,使用这个函数的最简单的方式是,在函数调用中只提供小狗的名字:
describe_pet('willie')
这个函数调用的输出与前一个示例相同。只提供了一个实参——'willie',这个实参将关联 到函数定义中的第一个形参——pet_name。由于没有给animal_type提供实参,因此Python使用其 默认值'dog'。
如果要描述的动物不是小狗,可使用类似于下面的函数调用:
describe_pet(pet_name='harry', animal_type='hamster')
由于显式地给animal_type提供了实参,因此Python将忽略这个形参的默认值。
注意 使用默认值时,在形参列表中必须先列出没有默认值的形参,再列出有默认值的实参。 这让Python依然能够正确地解读位置实参。
8.2.4 等效的函数调用
鉴于可混合使用位置实参、关键字实参和默认值,通常有多种等效的函数调用方式。请看下 面的函数describe_pets()的定义,其中给一个形参提供了默认值:
def describe_pet(pet_name, animal_type='dog'):
基于这种定义,在任何情况下都必须给pet_name提供实参;指定该实参时可以使用位置方式, 也可以使用关键字方式。如果要描述的动物不是小狗,还必须在函数调用中给animal_type提供 实参;同样,指定该实参时可以使用位置方式,也可以使用关键字方式。 下面对这个函数的所有调用都可行:
# 一条名为Willie的小狗 describe_pet('willie') describe_pet(pet_name='willie') # 一只名为Harry的仓鼠 describe_pet('harry', 'hamster') describe_pet(pet_name='harry', animal_type='hamster') describe_pet(animal_type='hamster', pet_name='harry')
这些函数调用的输出与前面的示例相同。
注意 使用哪种调用方式无关紧要,只要函数调用能生成你希望的输出就行。使用对你来说最 容易理解的调用方式即可。
8.2.5 避免实参错误
等你开始使用函数后,如果遇到实参不匹配错误,不要大惊小怪。你提供的实参多于或少于 函数完成其工作所需的信息时,将出现实参不匹配错误。例如,如果调用函数describe_pet()时 没有指定任何实参,结果将如何呢?
def describe_pet(animal_type, pet_name): """显示宠物的信息""" print("\nI have a " + animal_type + ".") print("My " + animal_type + "'s name is " + pet_name.title() + ".") describe_pet()
Python发现该函数调用缺少必要的信息,而traceback指出了这一点:
1 File "pets.py", line 6, in <module> 2 describe_pet() 3 TypeError: describe_pet() missing 2 required positional arguments: 'animal_ type' and 'pet_name'
在1处,traceback指出了问题出在什么地方,让我们能够回过头去找出函数调用中的错误。 在2处,指出了导致问题的函数调用。在3处,traceback指出该函数调用少两个实参,并指出了 相应形参的名称。如果这个函数存储在一个独立的文件中,我们也许无需打开这个文件并查看函 数的代码,就能重新正确地编写函数调用。
Python读取函数的代码,并指出我们需要为哪些形参提供实参,这提供了极大的帮助。这也 是应该给变量和函数指定描述性名称的另一个原因;如果你这样做了,那么无论对于你,还是可 能使用你编写的代码的其他任何人来说,Python提供的错误消息都将更有帮助。 如果提供的实参太多,将出现类似的traceback,帮助你确保函数调用和函数定义匹配。
Python:核心知识点整理大全16-笔记-2