python3 module中__init__.py的需要注意的地方

Posted Song榆钱儿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python3 module中__init__.py的需要注意的地方相关的知识,希望对你有一定的参考价值。

网上关于__init__.py的作用的资料到处都是,我在此就不再啰嗦哪些了。

若有需要、请各位看官去搜搜即可。

 

最近刚开始用Python3 就遇到了这个比较有意思的事情

闲言少叙,下面要介绍的是python3中__init__.py中的一些略微不同的地方

目录结构如下:

├── mdl
│   ├── __init__.py
│   ├── bar.py
│   └── foo.py
└── test.py

 

文件内容,从上至下,依次为

mdl/__init__.py:

#encoding:utf-8

from .foo import Foo    #python2、3都适用
from .bar import Bar    #python2、3都适用
#from mdl.foo import Foo    #python2、3都适用
#from mdl.bar import Bar    #python2、3都适用
#from foo import Foo    #python3不适用
#from bar import Bar    #python3不适用

 


mdl/bar.py:

class Bar():
    def __init__(self):
        pass


mdl/foo.py

class Foo():
    def __init__(self):
        pass

 

test.py

from mdl.foo import Foo
from mdl.bar import Bar
f = Foo()
b = Bar()

 

大家看到的贴的代码,可能就知道我所要说的是什么意思了吧……

对,没错。

之前在我们使用python2的时候(至少从python2.6之后是这样),我们通常将__init__.py置空(PS:置空的话,与python3也可以通用)或者直接(如下图所示)

from foo import Foo
from bar import Bar

然后可以正常地愉快地使用python test.py,没有任何报错信息。

 

但是在python3的时候(至少从python3.4之后是这样),我们这么来做

from foo import Foo
from bar import Bar

运行python test.py发现出错了,囧……

ImportError: No module named foo

 

别的我也不多说了,我想大家也都看明白了

建议,大家之后都使用这种方式(通用用法)

from .foo import Foo
from .bar import Bar

 

【附录】

1、在python2来运行程序(即python test.py)之后,发现

├── mdl
│   ├── __init__.py
│   ├── __init__.pyc
│   ├── bar.py
│   ├── bar.pyc
│   ├── foo.py
│   └── foo.pyc
└── test.py

(对,我们很常见的.pyc出现了)

2、在python3来运行程序之后,发现

├── mdl
│   ├── __init__.py
│   ├── __pycache__
│   │   ├── __init__.cpython-34.pyc
│   │   ├── bar.cpython-34.pyc
│   │   └── foo.cpython-34.pyc
│   ├── bar.py
│   └── foo.py
└── test.py

(看到了不同了吧……)

 

以上是关于python3 module中__init__.py的需要注意的地方的主要内容,如果未能解决你的问题,请参考以下文章

TypeError: module.__init__() 最多接受 2 个参数(给定 3 个)

python3.6 子类的__init__调用父类的__init__

在 Python 中导入深度嵌套的模块

python3报错No module named _ssl

异常解决-- AttributeError: cannot assign module before Module.__init__() call

异常解决-- AttributeError: cannot assign module before Module.__init__() call