模块 --- 最高级别程序组织单元
《Python学习手册》笔记
import 导入1个模块
from 获取模块指定变量名
imp.reload 重新载入模块文件代码的方法
模块作用
- 代码复用;
- 系统命名空间的划分;
- 实现共享服务和数据(跨系统共享组件);
import工作:
- 搜索;
- 编译;
- 运行。
模块搜索路径
- 程序主目录;
- PYTHONPATH目录(环境变量);
- 标准链接库;
- 任何.pth文件内容;
上面4步构成sys.path(模块搜索路径),sys.path可以查看当前搜索路径列表。
导入模块文件
- 源代码文件name.py;
- 字节码文件name.pyc;
- 目录name,包导入;
- 编译的扩展模块(通常为C/C++),导入时使用动态链接;
- 用C编写好的内置模块,通过静态连接至Python;
- ZIP文件组件,导入时自动解压;
- 内存映像,对于frozen可执行文件;;
- Java类(JPython);
- .Net组件(IronPython)。
import 导入
- from * 表示导入模块所有变量;
- 导入只发生1次;
- import和from是赋值语句,import将模块对象赋值给变量名,from将一或多变量名赋值给另一模块中同名对象;
- 修改模块内的变量和模块内变量和现模块变量名冲突时必须使用import导入;
模块命名空间
模块属性可通过__dict__/dir()进行获取。
模块重载(只能用于Python编写模块)
原因:模块在首次导入时加载执行,之后导入不会重新执行文件。
- reload内置函数;
- reload处理模块对象;
- reload位于模块之中,需导入自己;
- reload会在模块当前命名空间执行新代码,并对其命名空间进行覆盖;
- 文件顶层赋值语句使变量名变为新值;
- 重载会影响所有使用import读取了模块的客户端;
- 重载只会对以后使用from的客户端造成影响。
模块包导入
import dir1.dir2.mod
from dir1.dir2.mod import x
- 模块包的路径包含在sys.path中;
- 模块包路径目录下必须包含__init__.py文件(包初始化钩子),容器目录不需要此文件;
- 包首次导入时会执行__init__.py文件,用于初始化(__all__可以指定from *导入子模块的名称清单);
- import dir1.dir2.mod as mod
相对导入(只适用于包内导入)
相对导入 --- 导入只搜索包的目录,包目录为唯一搜索路径。
绝对导入 --- 导入搜索路径的模块。
- 只适用于包内模块文件import导入;
- 只是用于from语句;
高级模块话题
- 模块隐藏数据(_X变量和未包含在模块顶层__all__变量在from *导入时不会导入,但是import仍可访问);
- 启用实验特性(from feture import featurename);
- 混合用法模式(name 和 main,自我测试代码);
- 修改模块搜索路径(修改sys.path列表,仅在当前Python会话或进程有效);
- import和from语句as扩展(将模块或模块变量赋值给不同变量名);
- 使用名称字符串进行导入(exec('import '+ modulename) 或使用内置__import__函数(import(modulename));
- 过渡性模块重载(重载模块相关子部分);
模块设计理念
- 总在Python模块内编码;
- 模块耦合降到最低;
- 最大化模块黏合度;
- 尽量少修改其它模块变量。
模块注意事项
- 顶层代码语句次序先后;
- from复制变量名;
- from * 让变量语义模糊;
- reload不会影响之前的from导入;
- 递归形式(相互导入的模块调用)的from导入无法工作;