我想从同一目录中的另一个文件导入一个函数。
有时使用from.mymoduleimportmyfunction
对我有效,但有时我会得到一个:
SystemError: Parent module '' not loaded, cannot perform relative import
有时它与from mymodule import myfunction
一起工作,但有时我也会得到一个:
SystemError: Parent module '' not loaded, cannot perform relative import
我不明白这里的逻辑,也找不到任何解释。这看起来完全是随机的。
谁能给我解释一下这一切背后的逻辑是什么?
不幸的是,这个模块需要在包的内部,它也需要作为脚本运行,有时。知道我怎样才能做到吗?
这样的布局还挺常见的...
main.py
mypackage/
__init__.py
mymodule.py
myothermodule.py
...使用类似这样的mymodule.py
...
#!/usr/bin/env python3
# Exported function
def as_int(a):
return int(a)
# Test function for module
def _test():
assert as_int('1') == 1
if __name__ == '__main__':
_test()
#!/usr/bin/env python3
from .mymodule import as_int
# Exported function
def add(a, b):
return as_int(a) + as_int(b)
# Test function for module
def _test():
assert add('1', '1') == 2
if __name__ == '__main__':
_test()
...和类似这样的main.py
...
#!/usr/bin/env python3
from mypackage.myothermodule import add
def main():
print(add('1', '1'))
if __name__ == '__main__':
main()
...运行main.py
或MyPackage/MyModule.py
时运行得很好,但在运行MyPackage/MyOtherModule.py
时失败,原因是相对导入...
from .mymodule import as_int
你应该用的方式...
python3 -m mypackage.myothermodule
对于这种情况,假设名称mymodule
是全局唯一的,最简单的解决方法是避免使用相对导入,而只使用...
from mymodule import as_int
...虽然,如果它不是唯一的,或者您的包结构比较复杂,您将需要在pythonpath
中包含包含您的包目录的目录,这样做...
from mypackage.mymodule import as_int
...或者,如果您希望它“开箱即用”,您可以先在代码中使用以下命令来调用pythonpath
...
import sys
import os
PACKAGE_PARENT = '..'
SCRIPT_DIR = os.path.dirname(os.path.realpath(os.path.join(os.getcwd(), os.path.expanduser(__file__))))
sys.path.append(os.path.normpath(os.path.join(SCRIPT_DIR, PACKAGE_PARENT)))
from mypackage.mymodule import as_int
这是一种痛苦,但有一个线索,为什么在一封电子邮件由一个Guido van Rossum写...
我对此和任何其他关于__main__
机制的建议都持-1的观点。唯一的用例似乎是运行恰好位于模块目录中的脚本,我一直将其视为反模式。要让我改变主意你得让我相信这不是。
问题内容: 大家好-我正在用Python中的相关知识来表达自己的观点。我已经阅读了30篇文档,并在SO和其他论坛上阅读了很多帖子-似乎还是行不通。 我的目录结构目前看起来像这样 我希望expander.py和language_id.py可以访问功能模块。我运行python main.py,可以从components.expander import 和components.language_id i
我读了无数关于python中相对导入的讨论,我认为它如此令人困惑的原因之一是它在一个python版本之间发生了变化(我的版本是3.6)。但这里的罪魁祸首似乎是PyCharm(除非我弄错了..)我想知道是否有人找到了解决这个问题的办法。对于具有此布局的项目: 假设aa.py在文件中包含一些fuction,如果我编写这个导入: 因此,为了让PyCharm高兴,我可以将添加到导入中,然后错误似乎就解决了
问题内容: 我想从同一目录中的另一个文件导入函数。 有时它对我有用,但有时我得到: 有时它可与一起使用,但有时我也会得到: 我不了解这里的逻辑,也找不到任何解释。这看起来完全是随机的。 有人可以向我解释所有这些背后的逻辑是什么? 问题答案: 不幸的是,该模块需要位于程序包内部,有时还需要作为脚本运行。知道如何实现吗? 像这样的布局很普遍… … mymodule.py像这样… ......一个myo
问题内容: 我试图为一个简单的Python脚本生成可执行文件。我的setup.py代码如下所示: 但是,我得到了屏幕截图中显示的错误。有什么我可以尝试解决的吗?我正在使用Windows 10。 问题答案: 看来您在 mf3.py中导入的内容超出了顶层。 假设您的项目结构如下: 首先确保 main.py将子包称为: expander.py和language_id.py可以通过以下方式访问functi
问题内容: 这是我的文件夹结构: 在我有: 在时: 现在,当我发出: 我得到: 由于“多份原件打印”是在sys.path中,并正确地解决它为什么抱怨相对进口上述顶层包? 这是顶层包 ? 顺便说一句,这是我向旧项目中添加测试的尝试-在Python测试包布局中曾提出过要求,但作为Python单元测试去哪儿的副本被关闭了。对我当前的测试包布局的评论深表感谢! 那么下面的答案不适用于我的情况: 该 模块
问题内容: 我似乎无法让绝对导入在python中工作。这是我的文件结构: foo.py: 我反而得到: 这到底是怎么回事?我觉得我缺少基本的东西。尽管这个例子很简单,但我需要绝对导入才能为实际项目工作,因此仅用相对导入替换导入是不可行的。我正在使用python 2.7.13 预先感谢您的任何见解! 问题答案: 由于未显示,因此我必须假设您正在运行,这会将脚本()的目录放在开始的位置,而实际上您希望