下面通过一个例子说明:
目录结构如下:
├── 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