_ _init_ _.py文件
_ _init_ _.py控制着包导入行为。
_ _init_ _.py 为空,表示只导入这个包,不会导入包中的模块。
在 _ _init_ _.py 文件中,定义一个 _ _all__ 变量,控制从包名 import* 导入的模块。
内容可以写在_ _init_ _.py 文件中,导入时会执行这些语句。
__init__.py模块
__all__ = ["send","receive"]
print("你导入的msg包")
def test():
print("这里是msg包里面的test")
demo.py模块
import msg
msg.test()
运行结果为:
你导入的msg包
这里是msg包里面的test
嵌套的包
假定我们的包的例子有如下的目录结构:
A/#包A
__init__.py
a1.py
sub_B/#包B
__init__.py
b1.py
b2.py
sub_C/#包C
__init__.py
c1.py
c2.py
sub_D/#包D
__init__.py
d1.py
d2.py
A是顶层包,sub_B等是它的子包,我们可以这样导入子包:
import A.sub_B.b1
你也可使用 from-import 实现不同需求的导入。
第一种是只导入顶级子包,然后使用属性点运算符向下引用子包树:
from A import sub_B
sub_b.b2
此外,我们可以还引用更多的子包:
from A.sub_B import b1
事实上,你可以一直沿子包的树状结构导入。
在我们上面的目录结构中,我们可以找到很多 __init__.py 文件。这些是初始化模块,当 from-import 语句导入子包时需要这些模块。如果不使用,它们可以是空文件。
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ python中Break语句的中断12/31
- ♥ 如何重新安装python09/28
- ♥ 如何在手机上学习python11/21
- ♥ python参数解包的实现01/12
- ♥ python3如何判断key存在于字典中12/18
- ♥ Python如何生成xml文件11/02
内容反馈