python写脚本看xde文件_Python可以生成类似于bash的set -x的跟踪吗?

也许使用

sys.settrace:

使用traceit()打开跟踪,使用traceit(False)关闭跟踪.

import sys

import linecache

def _traceit(frame,event,arg):

'''

http://www.dalkescientific.com/writings/diary/archive/2005/04/20/tracing_python_code.html

'''

if event == "line":

lineno = frame.f_lineno

filename = frame.f_globals["__file__"]

if (filename.endswith(".pyc") or

filename.endswith(".pyo")):

filename = filename[:-1]

name = frame.f_globals["__name__"]

line = linecache.getline(filename,lineno)

print "%s # %s:%s" % (line.rstrip(),name,lineno,)

return _traceit

def _passit(frame,arg):

return _passit

def traceit(on=True):

if on: sys.settrace(_traceit)

else: sys.settrace(_passit)

def mktemp(src):

pass

def my_mktemp(src):

mktemp(src)

p=src

traceit()

for src in ('cpfs.c','log.c',):

my_mktemp(src)

traceit(False)

产量

mktemp(src) # __main__:33

pass # __main__:30

p=src # __main__:34

mktemp(src) # __main__:33

pass # __main__:30

p=src # __main__:34

if on: sys.settrace(_traceit) # __main__:26

else: sys.settrace(_passit) # __main__:27

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值