6.4 函数的参数

Python函数的参数传递都是使用传址调用的方式。所谓传址调用,就是将该参数的内存地址传过去,若参数在函数内被更改,则会影响到原有的参数。参数的数据类型可以是模块、类、实例(instance),或者其他的函数,用户不必在参数内设置参数的数据类型。

调用函数时可使用的参数类型包括必需参数、关键字参数、默认参数、可变参数和组合参数。下面分别介绍它们的使用方法和技巧。

6.4.1 必需参数

必需参数要求用户必须以正确的顺序传入函数。调用时的数量必须和声明时的一样,设置函数的参数时,须依照它们的位置排列顺序。例如:

运行结果如图6-17所示。从结果可以看出,调用gg(200, 50)时,x参数等于200,y参数等于50,因为Python会根据参数排列的顺序来取值。

图6-17 运行结果

如果调用gg ()函数时没有传入参数或传入参数与声明不同,就会出现语法错误。例如:

    >>> gg()            #不输入参数
    >>> gg(100,200,300)  #输入超过两个参数

运行结果如图6-18所示。从结果可以看出,无论是不传入参数还是传入的参数多于两个,都会提示报错信息。第一个错误信息表示需要传入x和y的值;第二个错误信息表示传入的参数为三个,多于规定的两个参数。

图6-18 运行结果

由此可见,对于包含必需参数的函数,在传递参数时需要保证参数的个数正确无误。

6.4.2 关键字参数

用户可以直接设置参数的名称及其默认值,这种类型的参数属于关键字参数。

在设置函数的参数时,可以不依照它们的位置排列顺序,因为Python解释器能够用参数名匹配参数值。例如:

运行结果如图6-19所示。

图6-19 运行结果

用户可以将必需参数与关键字参数混合使用,但必须将必需参数放在关键字参数之前。例如:

运行结果如图6-20所示。

图6-20 运行结果

6.4.3 默认参数

调用函数时,若没有传递参数,则会使用默认参数值。例如:

运行结果如图6-21所示。

图6-21 运行结果

在本示例中,首先定义一个函数gg( name, price=6000 ),这里变量price的默认值为6000。当第一次调用该函数时,因为指定了变量price的值为3880,所以输出值也为3880;第二次调用该函数时,因为没有指定变量price的值,所以结果将会输出变量price的默认值(6000)。

当使用默认参数时,参数的位置排列顺序可以任意改变。若每个参数值都定义了默认参数,则调用函数时可以不设置参数,使用函数定义时的参数默认值。

运行结果如图6-22所示。

图6-22 运行结果

6.4.4 可变参数

如果用户在声明参数时不能确定需要使用多少个参数,就使用可变参数。可变参数不用命名,其基本语法如下:

加了星号(*)的变量名会存放所有未命名的变量参数。如果在函数调用时没有指定参数,它就是一个空元组。用户也可以不向函数传递未命名的变量。

【例6.1】可变参数的综合应用(源代码\ch06\6.1.py)。

保存并运行程序,结果如图6-23所示。

图6-23 运行结果

从结果可以看出,用户无法预定参数的数目时,可以使用*arg类型的参数,*arg代表一个元组对象。在定义函数时,只定义两个参数,调用时可以传入两个以上的参数,这就是可变参数的优势。

用户也可以使用**arg类型的参数,**arg代表一个字典对象。

【例6.2】**arg类型的应用(源代码\ch06\6.2.py)。

保存并运行程序,结果如图6-24所示。

图6-24 运行结果