python - 如何从兄弟目录导入python模块?

我有一个具有以下结构的 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 . 将我的本地更改移动到站点包中。

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

但我无法理解它产生了什么差异。这是确切的问题-

  1. 如何解决这种情况下的 python 导入问题?
  2. 有没有更好的方法来构建 python 代码,这样我们就不会面临相对导入问题?
  3. -m unittest 解决这个问题有什么区别?

最佳答案

由于已经有很多关于 SO 的答案*,我将重点关注问题 (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

https://stackoverflow.com/questions/54361477/

相关文章:

python-3.x - Pandas df.to_sql 不适用于红移

google-maps - 如何使 flutter google map 中的标记随相机而不是 ma

python - 获取数组的最后一个索引的时间复杂度是多少?

r - 如何在绘图中制作垂直线段?

angular - 如何从测试代码中触发 Angular Material MatSelect 上的

python - 使用多行字符串时的缩进

c# - 如何生成包含 JSON 结构的要下载的文件?

ruby-on-rails - 使用 RubyZip 生成文件并下载为 zip

spring-boot - 斯波克测试 : Too few invocation

firebase - 限制经过身份验证的用户访问 Firestore