根据例子逐个分析
导入下一层目录中的文件
- 还是从
import开始吧。在原始的test_main.py文件内,仅仅加上import effects这句加载下层文件夹的代码。具体代码如下:
# 导入effects
import effects
# test_mian.py原始内容
print "============== test_main.py =============="
print dir()
def test():
print "============== test_main.test =============="
# main()
if __name__ == '__main__':
test()
运行结果:
============== effects.__init__ ==============
['__builtins__', '__doc__', '__file__', '__name__', '__package__', '__path__']
============== test_main.py ==============
['__builtins__', '__doc__', '__file__', '__name__', '__package__', 'effects']
============== test_main.test ==============
[Finished in 0.2s]
仔细查看运行结果显示,发现当import effects时,Python执行了这层文件夹对应的__init__.py,当然会把此文件编译成对应的.pyc文件。
- 上面的运行结果中,虽然
test_main的dir()包含了effects,但是effects没有包含任何文件夹下的模块,包括我们想要用到的echo.py。所以直接引用应该会不成功。
修改代码,增加effects.echo.test()的调用
# 导入effects
import effects
effects.echo.test()
# test_mian.py原始内容
print "============== test_main.py =============="
print dir()
def test():
print "============== test_main.test =============="
# main()
if __name__ == '__main__':
test()
运行结果,果然报了异常,提示没有echo
============== effects.__init__ ==============
['__builtins__', '__doc__', '__file__', '__name__', '__package__', '__path__']
Traceback (most recent call last):
File "E:\WorkSpace\Python\test\sound\test_main.py", line 5, in <module>
effects.echo.test()
AttributeError: 'module' object has no attribute 'echo'
[Finished in 0.2s with exit code 1]
-
直接
import导入下层目录文件,这样可以使用直接通过模块名来调用。
例如我们想要调用effects目录下echo.py文件内的test()函数,则可以import effects.echo,然后通过effects.echo.test()完成调用。需要指出的是,调用时的路径是全路径。代码如下:
# 导入echo
import effects.echo
effects.echo.test()
# test_mian.py原始内容
print "============== test_main.py =============="
print dir()
def test():
print "============== test_main.test =============="
# main()
if __name__ == '__main__':
test()
运行结果:
============== effects.__init__ ==============
['__builtins__', '__doc__', '__file__', '__name__', '__package__', '__path__']
============== echo.py ==============
['__builtins__', '__doc__', '__file__', '__name__', '__package__']
============== echo.test ==============
============== test_main.py ==============
['__builtins__', '__doc__', '__file__', '__name__', '__package__', 'effects']
============== test_main.test ==============
[Finished in 0.2s]
仔细观察运行结果,有几点需要看到:
1、test_main最终导入的是effects,而不是echo;所以引用时,才必须是全路径,也就是effects.echo
2、虽然我们要导入的是echo,但是effects下的__init__.py还是被导入执行了
-
通过
from import方式导入。其实这个方式跟上面区别不大,跟同级目录下方式差不多,调用时直接调用相关函数名。代码如下:
# 导入echo
from effects.echo import *
test()
test1()
# test_mian.py原始内容
print "============== test_main.py =============="
print dir()
def test():
print "============== test_main.test =============="
# main()
if __name__ == '__main__':
test()
运行结果:
============== effects.__init__ ==============
['__builtins__', '__doc__', '__file__', '__name__', '__package__', '__path__']
============== echo.py ==============
['__builtins__', '__doc__', '__file__', '__name__', '__package__']
============== echo.test ==============
============== echo.test1 ==============
============== test_main.py ==============
['__builtins__', '__doc__', '__file__', '__name__', '__package__', 'test', 'test1']
============== test_main.test ==============
[Finished in 0.2s]
test_main最终载入的是echo的两个函数对象。
- 上面的例子还能用另外一种方式调用。
通过from effects import echo载入echo,再用echo.test()方式调用函数,效果是一样的。