Python模組過載的五種方法

嗨学编程發表於2024-07-24

1.環境準備

新建一個 foo 資料夾,其下包含一個 bar.py 檔案

$ tree foo
foo
└── bar.py

0 directories, 1 file

bar.py 的內容非常簡單,只寫了個 print 語句

print("successful to be imported")

只要 bar.py 被匯入一次,就被執行一次 print

2.禁止重複匯入

'由於有 sys.modules 的存在,當你匯入一個已匯入的模組時,實際上是沒有效果的。'

>>> from foo import bar
successful to be imported
>>> from foo import bar
>>>

3.重複匯入方法一

如果你使用的 python2(記得前面在 foo 資料夾下加一個 __init__.py),有一個 reload 的方法可以直接使用

>>> from foo import bar
successful to be imported
>>> from foo import bar
>>>
>>> reload(bar)
successful to be imported
<module 'foo.bar' from 'foo/bar.pyc'>

如果你使用的 python3 那方法就多了,詳細請看下面

4.重複匯入方法二

如果你使用 Python3.0 -> 3.3,那麼可以使用 imp.reload 方法

>>> from foo import bar
successful to be imported
>>> from foo import bar
>>>
>>> import imp
>>> imp.reload(bar)
successful to be imported
<module 'foo.bar' from '/Users/MING/Code/Python/foo/bar.py'>

但是這個方法在 Python 3.4+,就不推薦使用了

<stdin>:1: DeprecationWarning: the imp module is deprecated in favour of importlib; see the module's documentation for alternative uses

5.重複匯入方法三

如果你使用的 Python 3.4+,請使用 importlib.reload 方法

>>> from foo import bar
successful to be imported
>>> from foo import bar
>>>
>>> import importlib
>>> importlib.reload(bar)
successful to be imported
<module 'foo.bar' from '/Users/MING/Code/Python/foo/bar.py'>

6.重複匯入方法四

還可以使用下面的方法

>>> from foo import bar
successful to be imported
>>> from foo import bar
>>>
>>> bar.__spec__.loader.load_module()
successful to be imported
<module 'foo.bar' from '/Users/MING/Code/Python/foo/bar.py'>

7.重複匯入方法五

既然影響我們重複匯入的是 sys.modules,那我們只要將已匯入的包從其中移除是不是就好了呢?

>>> import foo.bar
successful to be imported
>>>
>>> import foo.bar
>>>
#學習中遇到問題沒人解答?小編建立了一個Python學習交流群:531509025
>>> import sys
>>> sys.modules['foo.bar']
<module 'foo.bar' from '/Users/MING/Code/Python/foo/bar.py'>
>>> del sys.modules['foo.bar']
>>>
>>> import foo.bar
successful to be imported

有沒有發現在前面的例子裡我使用的都是 from foo import bar,在這個例子裡,卻使用 import foo.bar,這是為什麼呢?

這是因為如果你使用 from foo import bar 這種方式,想使用移除 sys.modules 來過載模組這種方法是失效的。

這應該算是一個小坑,不知道的人,會掉入坑中爬不出來。

>>> import foo.bar
successful to be imported
>>>
>>> import foo.bar
>>>
>>> import sys
>>> del sys.modules['foo.bar']
>>> from foo import bar
>>>

相關文章