GVKun编程网logo

Python中的相对导入(python 相对导入)

10

在本文中,我们将为您详细介绍Python中的相对导入的相关知识,并且为您解答关于python相对导入的疑问,此外,我们还会提供一些关于Heroku无法识别python模块的相对导入、python2.5

在本文中,我们将为您详细介绍Python中的相对导入的相关知识,并且为您解答关于python 相对导入的疑问,此外,我们还会提供一些关于Heroku 无法识别 python 模块的相对导入、python 2.5中的相对导入、Python 3 中的相对导入、Python 3中的相对导入的有用信息。

本文目录一览:

Python中的相对导入(python 相对导入)

Python中的相对导入(python 相对导入)

大家好-我正在用Python中的相关知识来表达自己的观点。我已经阅读了30篇文档,并在SO和其他论坛上阅读了很多帖子-似乎还是行不通。

我的目录结构目前看起来像这样

src/    __init__.py    main.py    components/        __init__.py        expander.py        language_id.py    utilities/        __init__.py        functions.py

我希望expander.py和language_id.py可以访问功能模块。我运行python main.py,可以从components.expander
import 和components.language_id import 访问模块。

但是,在expander和language_id内部的代码可以访问functions模块:

from ..utilities.functions import *

我收到此错误:

ValueError: Attempted relative import beyond toplevel package

我已经看了很多遍了,它似乎遵循了文档。有人对这里出什么问题有任何想法吗?

答案1

小编典典

没关系,我解决了它:

src/    main.py    mod/        __init__.py        components/            __init__.py            expander.py            language_id.py        utilities/            __init__.py            functions.py

然后main.py将子包称为:

from mod.components.expander import *from mod.utilities.functions import *

expander.py和language_id.py可以通过以下方式访问functions.py:

from ..utilities.functions import *

但是有趣的是,我在expander.py使用的components目录中有一个文本文件。但是,在运行时,即使文件位于同一目录中,也无法找到文件。我将文本文件移到了与main.py相同的目录中,并且可以正常工作。似乎违反直觉。

Heroku 无法识别 python 模块的相对导入

Heroku 无法识别 python 模块的相对导入

如何解决Heroku 无法识别 python 模块的相对导入?

我正在向 Heroku 部署一个 Flask 应用程序,但该应用程序崩溃了。在日志中,我注意到两件事引起了我的注意:

app[web.1]: [2021-07-21 16:50:59 +0000] [7] [ERROR] 工作进程异常

我的 procfile 如下所示:

web: gunicorn --chdir app app:app

第二个问题,我认为是问题的根源,是在生产中,我的相对导入没有被识别(文件结构如下):

app[web.1]:文件“/app/app/app.py”,第13行,
app[web.1]: from .models import (
app[web.1]: ImportError: 在没有已知父包的情况下尝试相对导入

这是我在开发环境中的(简化的)文件结构:

后端/
|-- .git/
|-- procfile
|-- __ 初始化 __.py
|-- 应用程序/
|---- | __ 初始化 __.py
|---- |应用程序.py
|---- |模型.py
|---- |认证/
|-------- | __ 初始化 __.py
|-------- | auth.py

如您所见,我在所有目录中添加了 __ init __.py 文件,使它们成为包/子包。该应用程序正在开发中运行。这是我如何在 app.py 中运行相对导入的快照:

from .models import (
db,setup_db,...
)

当我在 Heroku 中检查我的文件结构时,我发现目录“backend”不存在。它被“app”取代,但它仍然有 __init __.py 存在于“backend”中,app/app 包也是如此。

在 Heroku 中运行 bash 后,可以看到我上面的语句:

~ $ ls
app  __init__.py  procfile  requirements.txt  runtime.txt  test
~ $ cd app
~/app $ ls
app.py  auth  functions.py  __init__.py  manage.py  migrations  models.py  requirements.txt

我想我可以尝试将应用程序容器化并将其部署为映像,以避免开发和生产环境之间的差异。但是在我走这条路之前,我想知道有没有人知道如何在生产中解决这个问题?

解决方法

我重构了我的项目的架构,现在它可以工作了。谢谢@charchit 的见解。他们让我找到了答案。

这是我所做的:

后端/
|-- .gitignore
|-- Procfile
|-- 需求.txt
|-- 运行.py
|-- 应用程序/
|---- | __ 初始化 __.py
|---- |模型.py
|---- |认证/
|-------- | __ 初始化 __.py
|-------- | auth.py

变化:

  1. 从后端移除了 __init__py

  2. 删除了backend/app/app.py并将app.py的内容复制到backend/app/__init__.py

  3. run.py 添加到 backend/,这是 .git 所在的位置以及 Heroku 将在其中查找应用程序的位置。

run.py 看起来像这样:

from app import create_app

app = create_app()

if __name__ == ''__main__'':
    app.run()
  1. 将 Procfile 修改为:web: gunicorn run:app

  2. 在 app/init.py 中,导入看起来像这样

from .models import db,setup_db,Subject...
from .auth.auth import AuthError,requires_auth
etc ...

现在该应用程序在本地和生产环境中运行,其模块内没有任何冲突。呜呜!!!

python 2.5中的相对导入

python 2.5中的相对导入

我知道在Python中有很多关于相同导入问题的问题,但是似乎没有人能够提供正确用法的清晰示例。

比方说,我们有一个包mypackage有两个模块foobar。在内部,foo我们需要能够访问bar。

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

我们希望能够:

  • 进口 mypackage.foo
  • foo.py作为脚本运行,并执行本部分中的示例用法或测试__main__。
  • 使用Python 2.5

我们必须如何在foo.py中进行导入,以确保它在所有这些情况下都可以工作。

# mypackage/__init__.py
...

# mypackage/foo/__init__.py
...

# mypackage/bar.py  
def doBar()
    print("doBar")

# mypackage/foo/foo.py
import bar # fails with module not found
import .bar #fails due to ValueError: Attempted relative import in non-package

def doFoo():
    print(doBar())

if __name__ == '__main__':
    doFoo()

Python 3 中的相对导入

Python 3 中的相对导入

我想从同一目录中的另一个文件导入一个函数。

有时它对我有用,from .mymodule import myfunction但有时我得到:

SystemError: Parent module '' not loaded,cannot perform relative import

有时它适用于from mymodule import myfunction,但有时我也会得到:

SystemError: Parent module '' not loaded,cannot perform relative import

我不明白这里的逻辑,我找不到任何解释。这看起来完全随机。

有人可以向我解释这一切背后的逻辑是什么吗?

Python 3中的相对导入

Python 3中的相对导入

我想从同一目录中的另一个文件导入函数。

有时它对我有用,from .mymodule import myfunction但有时我得到:

SystemError: Parent module '''' not loaded, cannot perform relative import

有时它可与一起使用from mymodule import myfunction,但有时我也会得到:

SystemError: Parent module '''' not loaded, cannot perform relative import

我不了解这里的逻辑,也找不到任何解释。这看起来完全是随机的。

有人可以向我解释所有这些背后的逻辑是什么?

答案1

小编典典

不幸的是,该模块需要位于程序包内部,有时还需要作为脚本运行。知道如何实现吗?

像这样的布局很普遍…

main.pymypackage/    __init__.py    mymodule.py    myothermodule.py

… mymodule.py像这样…

#!/usr/bin/env python3# Exported functiondef as_int(a):    return int(a)# Test function for module  def _test():    assert as_int(''1'') == 1if __name__ == ''__main__'':    _test()

......一个myothermodule.py像这样…

#!/usr/bin/env python3from .mymodule import as_int# Exported functiondef add(a, b):    return as_int(a) + as_int(b)# Test function for module  def _test():    assert add(''1'', ''1'') == 2if __name__ == ''__main__'':    _test()

… main.py这样的…

#!/usr/bin/env python3from mypackage.myothermodule import adddef 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

…但是它有点冗长,并且无法与诸如的shebang行混合使用#!/usr/bin/env python3

假设名称mymodule在全球范围内是唯一的,这种情况下最简单的解决方法是避免使用相对导入,而只需使用…

from mymodule import as_int

…尽管它不是唯一的,或者您的包结构更复杂,您仍需要在中包含包含包目录的目录PYTHONPATH,并按以下步骤进行操作…

from mypackage.mymodule import as_int

…或者如果您希望它“开箱即用”工作,则可以PYTHONPATH使用此方法首先获取in代码…

import sysimport osPACKAGE_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 。唯一的用例似乎是正在运行的脚本,它们恰好位于模块的目录中,我一直将其视为反模式。为了让我改变主意,您必须说服我不要。

在程序包中运行脚本是否是反模式是主观的,但就我个人而言,我发现它在包含一些自定义wxPython小部件的程序包中非常有用,因此我可以为任何源文件运行脚本以wx.Frame仅显示包含该小部件用于测试目的。

关于Python中的相对导入python 相对导入的问题就给大家分享到这里,感谢你花时间阅读本站内容,更多关于Heroku 无法识别 python 模块的相对导入、python 2.5中的相对导入、Python 3 中的相对导入、Python 3中的相对导入等相关知识的信息别忘了在本站进行查找喔。

本文标签: