快速了解Python相對匯入

2022-10-04 20:27:31 字數 1754 閱讀 9910

1、絕對匯入和相對匯入

絕對匯入:程式設計客棧按照sys.path順序搜尋,先主目錄(sys.path中第一項''),然後pythonpath環境變數、標準庫路徑、pth指定路徑等。

相對匯入:在模組所在同乙個包內搜尋,注意該包目錄與主目錄的區別。

例1:有以下目錄

app/

__init__.py

mod.py

string.py

mod.py內容:import string

當在app/目錄下執行python mod.py時為絕對匯入,當在app上層目錄執行python -m app.mod時為相對匯入。

2、在python 2.7及之前版本中預設是先「相對」後「絕對」的順序搜尋模組,也就是說先在模組所在同乙個包內搜尋然後在sys.path中搜尋。

在上例中,在app上層目錄執行python -m app.mod時,將匯入app/string.py(可以在string.py中print或者在程式設計客棧mod.py中加入print string.__file__來測試)。

使用以下語句將會只搜尋絕對路徑:

from __future__ import 程式設計客棧absolute_import

在mod.py開頭加上該語句,在app上層目錄執行python -m app.mod時,將匯入標準庫中的string模組。

在python3.3中預設只搜尋絕對路徑,要使用相對匯入,執行以下語句:

from . import string

注意:開頭點號只能用在from語句中,不能用在import語句中。

3、相對匯入使用模組的__name__屬性來決定模組在包結構中的位置。當__name__屬性不包含包資訊(i.e. 沒有用'.'表示的層次結構,比如'__main__'),則相對匯入將模組解析為頂層模組,而不管模組在檔案系統中的實際位置。

例2:app/

__init__.py

sub1/

__init__.py

mod1.py

sub2/

__init__.py

mod2.py

嘗試在mod1.py匯入mod2.py,加入from ..sub2 import mod2。

直接在sub1目錄下執行python mod1.py或在app目錄下執行python sub1/mod1.py將報錯:"attempted relative import in non-package"。

在app目錄下執行python -m sub1.mod1也將報錯:"attempted relative import beyond toplevel package"。

正確的做法是:在app上層目錄執行python -m app.sub1.mod1,或者不要使用from ..sub2 import mod2而改用其他方式(比如將sub2新增到sys.path)。

例3:__init__.py

start.py

parent.py

sub/

__init__.py

relative.py

start.py中包含import sub.relative,relative.py中包含from .. import parent。

執行python start.py將報錯:"attempted relative import beyond toplevel package"。

解決辦法:新建pkg目錄,將parent.py、sub目錄移到pkg目錄中,start.py改為import pkg.sub.relative,其它不變。

總結

python 相對匯入

參考 python2 預設相對匯入 python3 預設絕對匯入 python3 相對匯入只有兩個方式 1.在上層有乙個檔案main.py,可以直接執行main.py main.py 裡 from mypackage.myothermodule imoprt 2.或者在包的外層執行 m python...

python相對匯入問題 Python 相對匯入

我正在開發乙個python程式,它在其中管理和執行模組 py python檔案 這些模組可以由使用者新增,並可以通過使用import函式匯入到主程式 foo.py 中.這是目錄結構 foo foo.py main script.imports ouput.py,core.py and bar.py ...

python 絕對匯入和相對匯入

今天在import自定義模組時遇到問題,在此記錄一下。假設檔案結構如下 project main.py utils a.py b.py 我想要實現乙個順序匯入main a b,即 main.py from utils import a a.py import b 然而在a.py報錯找不到b模組。因為...