@(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']
进行限制