对相关python进口的极限答案

前端之家收集整理的这篇文章主要介绍了对相关python进口的极限答案前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我知道 Python中有相同的导入问题有很多问题,但似乎没人设法提供正确使用的明确示例.

假设我们有一个包含两个模块foo和bar的软件包.里面的foo我们需要能够访问吧.

因为我们还在开发它,所以mypackage不在sys.path中.

我们希望能够:

> import mypackage.foo
>运行foo.py作为脚本,并从__main__部分执行示例使用或测试.
>使用Python 2.5

为了确保在所有这些情况下都能正常工作,我们必须在foo.py中进行导入.

  1. # mypackage/__init__.py
  2. ...
  3.  
  4. # mypackage/foo/__init__.py
  5. ...
  6.  
  7. # mypackage/bar.py
  8. def doBar()
  9. print("doBar")
  10.  
  11. # mypackage/foo/foo.py
  12. import bar # fails with module not found
  13. import .bar #fails due to ValueError: Attempted relative import in non-package
  14.  
  15. def doFoo():
  16. print(doBar())
  17.  
  18. if __name__ == '__main__':
  19. doFoo()

解决方法

看看 PEP 328的以下信息:

Relative imports use a module’s __name__ attribute to determine that module’s position in the package hierarchy. If the module’s name does not contain any package information (e.g. it is set to '__main__') then relative imports are resolved as if the module were a top level module,regardless of where the module is actually located on the file system.

当您将foo.py作为脚本运行时,该模块的__name__是“__main__”,因此您不能进行相对导入.即使mypackage在sys.path上也是如此.基本上,如果导入了该模块,则只能从模块进行相对导入.

以下是解决这个问题的几个选择:

1)在foo.py中,检查是否__name__ ==’__main__’,并有条件地将mypackage添加到sys.path中:

  1. if __name__ == '__main__':
  2. import os,sys
  3. # get an absolute path to the directory that contains mypackage
  4. foo_dir = os.path.dirname(os.path.join(os.getcwd(),__file__))
  5. sys.path.append(os.path.normpath(os.path.join(foo_dir,'..','..')))
  6. from mypackage import bar
  7. else:
  8. from .. import bar

2)始终使用mypackage导入栏导入栏,并执行foo.py,使得mypackage可以自动显示

  1. $cd <path containing mypackage>
  2. $python -m mypackage.foo.foo

猜你在找的Python相关文章