如何在sys.settrace中打印函数参数?

发布于 2021-01-29 16:28:23

如何检查sys.settrace调用中的函数参数的值?似乎我有可能输出除参数以外的几乎所有内容(行,文件名,堆栈跟踪,返回值等)。有没有可以让我跟踪函数参数值的解决方法?

关注者
0
被浏览
35
1 个回答
  • 面试哥
    面试哥 2021-01-29
    为面试而生,有面试问题,就找面试哥。

    您可以结合使用代码对象和框架对象。

    请参阅《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", "!")
    

    要实现的关键是

    1. 我们可以看到框架中的所有局部变量为f_locals
    2. 我们可以从中提取参数列表中变量的名称f_code.co_varnames


知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看