gpt4 book ai didi

python - inspect.getmodule 的结果在 os.chdir 之后改变

转载 作者:行者123 更新时间:2023-11-28 19:26:07 26 4
gpt4 key购买 nike

我的一些代码突然出现了一个错误。当我追踪它时,我发现在执行 os.chdir 之前和之后使用相同(相同)参数评估 inspect.getmodule 会给出不同的结果。

(FWIW,我在 OS X 下运行 Python 2.7.3。)

我发现这种行为非常令人费解和困惑,以至于我不知道如何最好地修复这个错误。 (换句话说,理解了行为的原因,我能想到的任何解决方案都只是创可贴。)

下面的测试脚本说明了行为(当然,现实生活中的错误发生在更现实和复杂的环境中):

import inspect
import os

def prn(line, mod):
print ('getmodule called at line %2d; returned module: %-8s (id: %d)' %
(line - 1, getattr(mod, '__name__', mod), id(mod)))

fr = inspect.currentframe()

mod = inspect.getmodule(fr) # line 10
prn(fr.f_lineno, mod)

mod = inspect.getmodule(fr) # line 13
prn(fr.f_lineno, mod)

os.chdir('subdir')

mod = inspect.getmodule(fr) # line 18
prn(fr.f_lineno, mod)

(注意:运行此代码要求在当前目录下有一个名为“subdir”的子目录。)

它的输出是:

getmodule called at line 10; returned module: __main__ (id: 4297636784)
getmodule called at line 13; returned module: __main__ (id: 4297636784)
getmodule called at line 18; returned module: None (id: 4296513024)

请注意,虽然对 getmodule 的所有三个调用都将相同的框架对象作为参数,但最后一个的结果与前两个的结果不同。 (前两次调用的结果是相同的,正如人们所期望的那样。)

前两个调用与第三个调用之间的唯一区别是后者发生在运行 os.chdir 之后。

任何关于正在发生的事情的见解都将不胜感激。

最佳答案

我尝试在 Windows 7 X64 上的 Idle Python 2.7.2 和 2.7.3 上运行代码,但是,我无法重现它。我得到的只是:-

getmodule called at line 12; returned module: main (id: 31281464)
getmodule called at line 15; returned module: main (id: 31281464)
getmodule called at line 20; returned module: main (id: 31281464)

但是,我认为问题在于实现。正如 Python 文档中所示:http://docs.python.org/library/inspect.html#inspect.getmodule , 尝试猜测对象是在哪个模块中定义的。

我认为(这只是一个假设,因为我无法在我的系统上重现您的观察结果)在您更改当前目录之前,因为您在父目录中,该模块显示为 ma​​in,因此您收到 id:4297636784。但是,在更改当前目录后,无法从新目录引用该模块,因此返回给您的新 id:4296513024 和 None 作为模块,因为 无法从新目录引用主模块。

关于python - inspect.getmodule 的结果在 os.chdir 之后改变,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12019061/

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