易百教程

94、如何在 Python 中监控程序的代码流?

在 Python 中,可以使用 sys 模块的 settrace() 方法来设置跟踪挂钩并监控程序内部的函数。需要定义一个跟踪回调方法并将其传递给 settrace() 函数。 回调应指定三个参数,如下所示:

import sys

def trace_calls(frame, event, arg):
    # The 'call' event occurs before a function gets executed.
    if event != 'call':
        return
    # Next, inspect the frame data and print information.
    print 'Function name=%s, line num=%s' % (frame.f_code.co_name, frame.f_lineno)
    return

def demo2():
    print 'in demo2()'

def demo1():
    print 'in demo1()'
    demo2()

sys.settrace(trace_calls)
demo1()