本节主题为函数(functions),精萃段落如下:当我们用 Python 编程的时候,更多的情况下,只不过是在使用别人已经写好的 “已完好封装的函数”。所谓的 “学习使用函数”,就是 “通过阅读产品说明书了解如何使用产品” 。
函数,实际上是可被调用的完整的程序。它具备输入、处理、输出的功能。了解一个函数,无非是要了解它的两个方面:
它的输入是怎么构成的(参数?如何指定?);
以及它的输出是什么(返回值究竟是什么?)……
print()函数示例
1 print()最基本的作用就是把传递给它的值输出到屏幕上,如果不给它任何参数,那么它就输出一个空行:
print() 的官方文档说明中最必须读懂的部分,就是这一行
print(*object, sep=' ', end='\n', file=sys.stdout, flush=False) [1]
sep=' '、end='\n'、file=sys.stdout:这三个具有默认值的参数,即便我们在调用这个函数的时候,没有指定它们,它们也依然存在。
sep=' ':接收多个参数之后,输出时,分隔符号默认为空格,' ';
end='\n':输出行的末尾默认是换行符号 '\n';
file=sys.stdout:默认的输出对象是 sys.stdout(即,用户正在使用的屏幕)……
2 print() 这个函数是可以往文件里写数据的,只要指定 file 这个参数为一个已经打开的文件对象就可以了
3 print() 这个函数的返回值是 None —— 注意,它向屏幕输出的内容,与 print() 这个函数的返回值不是一回事。
函数的参数
在 Python 中,函数的参数,有两种:
位置参数(Positional Arguments,在官方文档里常被缩写为 arg)
关键字参数(Keyword Arguments,在官方文档里常被缩写为 kwarg)
在函数定义中,带有 = 的,即,已为其设定了默认值的参数,叫做 Keyword Arguments,其它的是 Positional Arguments。
在调用有 Keyword Arguments 的函数之时,如若不提供这些参数,那么参数在执行时,启用的是它在定义的时候为那些 Keyword Arguments 所设定的默认值;如若提供了这些参数的值,那么参数在执行的时候,启用的是接收到的相应值。
位置参数,顾名思义,是 “由位置决定其值的参数”。拿商余函数 divmod() 为例,它的官方文档是这样写的:
它接收且必须接收两个参数。
当你调用这个函数的时候,括号里写的第一个参数,是被除数,第二个参数是除数 —— 此为该函数的输入;
而它的返回值,是一个元组(Tuple,至于这是什么东西,后面讲清楚),其中包括两个值,第一个是商,第二个是余 —— 此为该函数的输出。
可选的位置参数
有些函数,如 pow(),有可选的位置参数(Optional Positional Arguments)。
于是,pow() 有两种用法,各有不同的结果:
pow(x, y) —— 返回值是 x ** y
pow(x, y, z) —— 返回值是 x ** y % z
可接收很多值的位置参数
print(*object, sep=' ', end='\n', file=sys.stdout, flush=False) 函数中, 它的第一个位置参数,object 前面是有个星号的:*object, 对函数的用户来说,这说明,这个位置可以接收很多个参数(或者说,这个位置可以接收一个列表或者元组)。
再仔细看看 print(),它只有一个位置参数:
因为位置决定了值的定义,一般来说,一个函数里最多只有一个这种可以接收很多值的位置参数 —— 否则如何获知谁是谁呢?
如果与此同时,还有若干个位置参数,那么,能够接收很多值的位置参数只能放置最后,
划重点
1 调用函数的时候,注意可选位置参数的使用方法和关键字参数的默认值;
2 函数定义部分,注意两个符号就行了,[] 和 =;
3 所有的函数都有返回值,即便它内部不指定返回值,也有一个默认返回值:None;
4 一定要耐心阅读该函数在使用的时候需要注意什么
体会
书中有一段落读第一遍不知其意,多看几次才有所理解,如下:
print(print(1)) 这个语句 —— print() 这个函数被调用了两次,第一次是 print(1),它向屏幕输出了一次,完整的输出值实际上是 str(1) + '\n',而后返回一个值,None;而第二次调用 print(),这相当于是向屏幕输出这个 None:
print(print(1))
1
None