如何从同级目录导入python模块?

时间:2019-01-25 08:24:50

标签: python module python-import resolution

我有一个具有以下结构的python(3.6.3)项目

setup.py
utils #python package
utils/constants.py
utils/name_reports.py
normalization #python package
normalization/resolve_name.py
categorization #python package
categorization/animal_categories.py

您可以在github上找到源代码-https://github.com/techmango-org/python-import-resolution

这是utils/name_reports.py

的源代码
import normalization.resolve_name as rn
import categorization.animal_categories as ac

test_name = 'DOGY'
resolved_name = rn.get_animal_name(test_name)

print('********ANIMAL CATEGORY IS:', ac.get_animal_score(resolved_name))

运行python utils/name_reports.py时出现以下异常

Traceback (most recent call last):
  File "utils/name_reports.py", line 1, in <module>
    import normalization.resolve_name as rn
ModuleNotFoundError: No module named 'normalization'

我试图通过运行pip install .将当前程序包安装到虚拟环境站点程序包中来解决此问题,但这意味着对于每个本地更改,我都必须运行pip install --upgrade .才能将本地更改程序移至站点中包。

我一直在使用黑客-m unittest来解决此问题。检查此屏幕截图

enter image description here

但是我无法理解它会带来什么不同。这是确切的问题-

  1. 在这种情况下如何解决python导入问题?
  2. 是否有更好的方法来构造python代码,以使我们不会遇到相对的进口问题?
  3. -m unittest在创造什么,解决了这个问题?

2 个答案:

答案 0 :(得分:2)

由于对此*已经有很多答案,所以我将重点讨论问题(2)。关于什么是更好的代码组织:

|- setup.py
|- top_pkg_name
    |- __init__.py
    |- pkg1
        |- __init__.py
    |- pkg2
        |- __init__.py

(相对)导入是从module_2内部完成的,如下所示:

from ..pkg1 import module1 as m1

或者,您可以使用绝对导入,这是指顶级软件包名称:

from top_pkg_name.pkg1 import module1 as m1

在这样的组织中,当您想将任何模块作为脚本运行时,必须使用-m标志:

python -m top_pkg_name.pkg1.module1

对于问题(3),我不确定,但是好像unittest模块将文件夹添加到路径,从而允许直接进行导入。

*参考:

  1. How do I import a Python script from a sibling directory?
  2. Python import module from sibling folder

答案 1 :(得分:0)

使用导入语句:

from normalization import resolve_name
from categorization import animal_categories

您的代码:

from normalization import resolve_name as rn
from categorization import animal_categories as ac

test_name = 'DOGY'
resolved_name = rn.get_animal_name(test_name)

print('********ANIMAL CATEGORY IS:', ac.get_animal_score(resolved_name))