python中__init__.py作为封包的使用与模块导入的执行过程

1.python中的Module是比较重要的概念。常见的情况是,事先写好一个.py文 件,在另一个文件中需要import时,将事先写好的.py文件拷贝 到当前目录,或者是在sys.path中增加事先写好的.py文件所在的目录,然后import。这样的做法,对于少数文件是可行的,但如果程序数目很多,层级很复杂,就很吃力了。有没有办法,像Java的Package一样,将多个.py文件组织起来,这就用到了__init__的封包操作。

2.在使用__init__的封包操作之前,我们先了解下import语句时,python做了哪些操作

 1.创建一个新的,空的module对象

    2.把这个module对象插入sys.module中

    3.装载module的代码

    4.执行新的module中对应的代码

在执行第3步时,首先要找到module程序所在位置,其查找顺序如下

 1.在当前路径以及当前目录指定的sys.path

    2.从环境变量PYTHONPATH进行查找

 3.pyhon的安装设置相关的默认路径

如果当前路径或者PYTHONPATH存在与标准module相同的module,则会覆盖标准module,也就是说,如果当下目录存在xml.py 那么执行import xml.py时,导入的当前目录下的module,而不是系统标准的xml。

3.了解完python import导入的机制后,我们就可以先构建一个package,以普通module的方式导入,就可以直接访问此package中的各个module了。

Python中的package定义很简单,其层次结构与程序所在目录的层次结构相同,这一点与Java类似,唯一不同的地方在于,python中的package必须包含一个__init__.py的文件。
例如,我们可以这样组织一个package: (package1和package2为两个同级的文件包)

package1/
    __init__.py
    module_a.py
    module_b.py
package2/
        __init__.py
        module_c.py

module_a.py中定义一个函数:
def funA():
    print ("我是来自 module_a")
    return 1
module_b.py中定义一个函数:
def funB():
    print ("我是来自 module_b")
    return 2

我们想在package2的module_c中执行funA 和funB

我们可以在 module_c.py中分别导入package1中的模块 module_a.py和module_b.py。

from package1.module_a import funA
from package1.module_b import funB
funA()
funB()

上面一种方法虽然可以完成对文件模块的导入,但是当我们想要在文件加载后第一时间执行,并且直接得出funA和funB的返回值相加。这个时候我们使用__init__的封包操作更为方便些:

我们可以对package1的__init__.py 定义一个funC:

from .module_a import funA
from .module_b import funB
def funC():
    ret1=funA()
    ret2=funB()
    return int(ret1)+int(ret2)

然后在我们想在package2的module_c直接从package1导入funC()即可

from .package1 import funC
funC()
*****执行结果*****
我是来自 module_a
我是来自 module_b

3

 

转载于:https://www.cnblogs.com/dushangguzhousuoli/p/11121956.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值