何时或为什么在 Python 中使用相对导入

When or why to use relative imports in Python(何时或为什么在 Python 中使用相对导入)
本文介绍了何时或为什么在 Python 中使用相对导入的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

是否有任何关于何时在 Python 中使用相对导入的规则或指南?我一直在使用它们,就像在 Flask Web 框架中一样.在搜索这个主题时,我只看到有关如何使用相对导入的文章,而没有看到为什么.

Is there any rules or guidelines concerning when to use relative imports in Python? I see them in use all the time like in the Flask web framework. When searching for this topic, I only see articles on how to use relative imports, but not why.

那么使用有什么特别的好处:

So is there some special benefit to using:

from . import x

而不是:

from package import x

此外,我注意到相关的 SO 帖子 提到不鼓励相对导入.然而人们仍在继续使用它们.

Moreover, I noticed that a related SO post mentions that relative imports are discouraged. Yet people still continue to use them.

推荐答案

查看 PEP 328 关于相对进口的部分

理由似乎是这样写的:

展示了几个用例,其中最重要的是能够重新排列大型包的结构,而无需编辑子包.此外,包内的模块在没有相对导入的情况下无法轻松导入自身.

Several use cases were presented, the most important of which is being able to rearrange the structure of large packages without having to edit sub-packages. In addition, a module inside a package can't easily import itself without relative imports.

这篇关于何时或为什么在 Python 中使用相对导入的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)
Grouping pandas DataFrame by 10 minute intervals(按10分钟间隔对 pandas 数据帧进行分组)