2017-9-3 8.6 将函数存储在模块中

函数的优点之一是,使用它们可将代码块与主程序分离。通过给函数指定描述性名称,可让主程序容易理解得多。你还可以更进一步,将函数存储在被称为模块 的独立文件中,再将模块导入 到主程序中。import 语句允许在当前运行的程序文件中使用模块中的代码。

通过将函数存储在独立的文件中,可隐藏程序代码的细节,将重点放在程序的高层逻辑上。这还能让你在众多不同的程序中重用函数。将函数存储在独立文件中后,可与其他程序员共享这些文件而不是整个程序。知道如何导入函数还能让你使用其他程序员编写的函数库。

8.6.1 导入整个模块

要让函数是可导入的,得先创建模块。模块 是扩展名为.py的文件,包含要导入到程序中的代码。


2017-9-3 8.6 将函数存储在模块中_第1张图片
建立模块文件pizza.py


2017-9-3 8.6 将函数存储在模块中_第2张图片
在pizza.py所在的目录中创建另一个名为making_pizzas.py的文件,这个文件导入刚创建的模块,再调用make_pizza() 两次

导入方法:只需编写一条import 语句并在其中指定模块名,就可在程序中使用该模块中的所有函数。

8.6.2 导入特定的函数

通过用逗号分隔函数名,可根据需要从模块中导入任意数量的函数:

from module_name import function_0, function_1, function_2


2017-9-3 8.6 将函数存储在模块中_第3张图片
。由于我们在import 语句中显式地导入了函数make_pizza() ,因此调用它时只需指定其名称。即可以少写一层调用。

8.6.3 使用as 给函数指定别名

可指定简短而独一无二的别名 ——函数的另一个名称,类似于外号。要给函数指定这种特殊外号,需要在导入它时这样做。

关键字as 将函数重命名为你提供的别名:


2017-9-3 8.6 将函数存储在模块中_第4张图片
from module_name import function_name as fn

8.6.4 使用as 给模块指定别名


2017-9-3 8.6 将函数存储在模块中_第5张图片
import module_name as mn


8.6.5 导入模块中的所有函数

使用星号(* )运算符可让Python导入模块中的所有函数:


由于导入了每个函数,可通过名称来调用每个函数,而无需使用句点表示法

最好不要采用这种导入方法。

最佳的做法是,要么只导入你需要使用的函数,要么导入整个模块并使用句点表示法。

8.7 函数编写指南

作业:

选择一个你编写的且只包含一个函数的程序,并将这个函数放在另一个文件中。在主程序文件中,使用下述各种方法导入这个函数,再调用它:

import module_name

from module_name import function_name

from module_name import function_name as fn

import module_name as mn

from module_name import *

remark:

应给函数指定描述性名称,且只在其中使用小写字母和下划线。描述性名称可帮助你和别人明白代码想要做什么。

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

只要知道函数的名称、需要的实参以及返回值的类型,就能在自己的程序中使用它。

给形参指定默认值时,函数调用中的关键字实参,等号两边不要有空格:

def function_name(parameter_0, parameter_1='default value')

function_name(value_0, parameter_1='value')

模块包含多个函数,可使用两个空行将相邻的函数分开。

你可能感兴趣的:(2017-9-3 8.6 将函数存储在模块中)