如何在sys.settrace中打印函数参数?
问题内容:
如何检查sys.settrace调用中的函数参数的值?似乎我有可能输出除参数以外的几乎所有内容(行,文件名,堆栈跟踪,返回值等)。有没有可以让我跟踪函数参数值的解决方法?
问题答案:
您可以结合使用代码对象和框架对象。
请参阅《Python数据模型参考》中有关这些内容的描述。
import sys
def fn(frame, msg, arg):
if msg != 'call': return
# Filter as appropriate
if frame.f_code.co_filename.startswith("/usr"): return
print("Called", frame.f_code.co_name)
for i in range(frame.f_code.co_argcount):
name = frame.f_code.co_varnames[i]
print(" Argument", name, "is", frame.f_locals[name])
sys.settrace(fn)
def hai(a, b, c):
print(a, b, c)
hai("Hallo", "Welt", "!")
要实现的关键是
- 我们可以看到框架中的所有局部变量为
f_locals
。 - 我们可以从中提取参数列表中变量的名称
f_code.co_varnames
。