2

我正在使用python 的trace模块来跟踪一些代码的执行。我注意到,当稍后打印执行时,它以以下形式打印(下面是最小的工作示例):

<filename>(<line number>): <line of code>

可以获得完整的(绝对或相对)文件路径,而不仅仅是文件名。在调用的某个地方会有一个标志trace.Trace应该允许我这样做是有道理的,但我似乎无法在文档中找到任何这样的参数。

如果这样的标志不存在,我将如何获取文件路径?我想我可以检查 中的所有目录sys.path,但是我将如何处理两个不同目录具有相同名称的文件的情况?

4

1 回答 1

0

这不是很明显,但我发现如果我使用countfuncsin 参数trace,或者--listfuncs如果我trace从命令行使用参数,我会得到完整的路径名。因此,对于程序:

import trace
from recurse import recurse

tracer = trace.Trace(count=False, trace=True, countfuncs=True)
tracer.run('recurse(2)')
tracer.results().write_results()

...(使用 Doug Hellmann's example from here)我得到以下输出:

functions called:
filename: <string>, modulename: <string>, funcname: <module>
filename: C:\Python33\lib\encodings\cp850.py, modulename: cp850, funcname: IncrementalEncoder.encode
filename: C:\Python33\lib\trace.py, modulename: trace, funcname: _unsettrace
filename: C:\usr\sjl\dev\test\python\recurse.py, modulename: recurse, funcname: recurse

这不是您要查找的内容,因为您可以看到它忽略了跟踪代码行的指令,因此它没有在这些代码行旁边提供文件路径。但是,它确实可以准确地告诉您 Python 脚本正在使用哪些文件。

于 2013-01-24T08:27:42.160 回答