gpt4 book ai didi

python - Monkey 修补导入此模块的模块

转载 作者:太空宇宙 更新时间:2023-11-03 16:37:43 26 4
gpt4 key购买 nike

因此,我有一个具有此功能的 Python 应用程序,其中程序目录的 extensions 子目录中的任何类似模块的文件都会在应用程序初始化过程的早期阶段导入。

这看起来像这样(假设这是my_application.py):

def do_init():
for thefname in glob.iglob(os.path.join(".","extensions","*")):
SourceFileLoader(os.path.basename(thefname),thefname).load_module()
#do other init stuff...

if __name__ == "__main__":
do_init()
do_cool_things()

现在,我希望能够在该扩展目录中有一个 .py 文件,如下所示:

import my_application
def my_cool_things():
print("The original things have been overridden.")
my_application.do_cool_things = my_cool_things

这适用于将来导入 my_application。但是 if __name__ == "__main__" 防护内的 do_cool_things 调用表现出了原始行为。为什么会发生这种情况以及如何使该调用表现出修改后的行为?

最佳答案

令人惊讶的是,通过运行名为 my_application.py 的脚本创建的模块不是 my_application。通过运行脚本创建的模块是__main__。当然,通过导入名为 my_application.py 的文件创建的模块将被称为 my_application

解决您问题的两种方法是将 import my_application 替换为 import __main__importbuiltins

简单演示:

#x.py
import y
print ("Hello", hello)

#y.py
import __main__
__main__.hello = 'world'

在 Ubuntu 14.04 上使用 Python 3.4.3 进行测试:

$ python3 x.py
Hello world
$

关于python - Monkey 修补导入此模块的模块,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37074991/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com