模块化编程的流程
- 设计API,进行功能描述;
- 编码实现API中描述的功能;
- 在模块中编写测试代码,并消除全局代码;
- 使用私有函数实现不被外部客户端调用的模块函数
模块API和功能描述
API:应用程序编程接口,描述模块中提供的函数和类的功能及其使用方法
company = '刘美丽丽人公司'
def yearSalary(monthSalary):
"""根据传入月薪的值,计算出年薪:monthsalary*12"""
return monthSalary*12
def daySalary(monthSalary):
"""根据传入的月薪值,计算出1天的薪资,一个月按照22.5天计算"""
return monthSalary/22.5
# __doc__可获得模块的文本说明
调用
import mypy002
print(mypy002.__doc__)
print(mypy002.daySalary.__doc__)
模块的创建和测试代码
__name__获取模块名称,正常情况下,模块名称即为模块的文件名。
print(mypy002.__name__)
当模块作为程序的入口时,其__name__的值为 “main”
if __name__ == '__main__':
print(yearSalary(5000))
模块的导入
在本模块中使用其他模块
impo语句导入
import导入模块
form_import导入模块中的函数
语法:
import 模块名
import 模块1,模块2
import 模块名 as 模块别名 #导入模块并使用新名字
import加载的模块有四个通用类别:
- 使用python编写的代码(.py文件)
- 已被编译为共享库或DLL的C或C++扩展
- 包好一组模块的包
- 使用C编写并链接到python解释器的内置模块
导入本质上是导入了一个对象,导入模块实际会生成一个module的对象,使用了内置函数__import__()
模块不论被加载多少次都是一个对象
from … import…导入模块中的一个函数
from math import add
import()动态导入,importlib也可实现动态导入,推荐使用此语句而非__import__()
m = __import__()
m.pi
a = importlib.import_module(s)
#重新加载模块
import importlib
importlib.reload(mypy002)
包的创建和导入包
包的概念和模块
包相当于一个文件夹,,用于组织管理模块,模块相当于其中的子文件。包中必须包含一个初始化的文件“init.py”,这是包和文件夹的本质区别。包中可以放子包。
包的导入
导入包本质是“导入了包的__init__.py”文件,即执行了__init__.py
init.py文件的三个核心作用:
1.作为包的标识,不能删除
2.用来实现模糊导入: import *(不建议使用)
3.导入包实质是执行__init__.py文件,可以在该文件中做这个包的初始化,以及需要统一执行的代码和批量导入
import a.aa.moda1
from a.aa import moda1
用*导入包
同级目录:使用.
上级目录:使用…
sys.path和模块搜索路径
当导入一个模块时,解释器寻找该模块的顺序为:
1.内置模块
2.当前目录
3.程序的主目录
4.pythonpath目录(如果已经设置了)
5.标准链接库目录
6.第三方库目录(site-packages目录)
7. .pth文件的内容(如果存在的话)
8. sys.path.append()临时添加的目录