python 模块与包

@(python)

模块封包组织代码

如下一个包的层级组成:

├── module_a.py
├── package_bc
│   ├── __init__.py
│   ├── module_b.py
│   ├── module_c.py
│   └── package_sub
│       ├── __init__.py
│       └── module_s.py
├── package_de
│   ├── __init__.py
│   ├── module_d.py
│   └── module_e.py
└── test.py

每个文件夹对应一个包,包里面可以包含多个包,对应的每个 .py 文件是一个具体模块。
封装成包,在文件上组织好代码后,确保每个目录都要一个 __init__.py文件即可; 默认这个文件是空的,在 import 对应包的时候会被调用,也可以在其中写入其他语句作为导入包的初始化设置,如下

#  package_de/__init__.py
#!/usr/bin/env python
# coding=utf-8
# by orientlu
from . import module_d
from .module_e import module_e_fun
if __name__ == "__main__":
   pass

在导入包的时候就把其下子模块导入了。注意导入两个模块的写法的细微差异,再导入后的调用方式上的差别。

对于多个 .py 文件分别定义了多个类,但是想把这几个文件归属为一个模块的时候,可以参考 module_e 导入方式。

对于上述层次结构的模块组织,调用各个包下模块示例 :

## test.py 
#!/usr/bin/env python
# coding=utf-8
# by orientlu

import module_a as ma
import package_bc.module_c
import package_bc.module_b as mb
import package_bc.package_sub.module_s as ms
import package_de

if __name__ == "__main__":
    ma.module_a_fun()
    mb.module_b_fun()
    package_bc.module_c.module_c_fun()
    ms.module_s_fun()
    package_de.module_d.module_d_fun()
    package_de.module_e_fun()

限制模块导入所有的内容

一般不推荐
from module import *, 导入很多不用的模块内容容易污染当前的命名空间。

如果模块里面什么都没做,执行上述语句会导入模块中所有不以下划线开头的函数,变量。
通过在模块中添加语句
__all__ = ['fun1', 'fun2']
进行限制

测试代码

参考

python3-codebook

你可能感兴趣的:(python 模块与包)