我可以设置一个全局标志并有条件地运行它,但后来我失去了单行断点的’standalone-ness’,还需要为每个pdb.set_trace()另一个标志.
解决方法 我的另一个答案是快速破解,并不完美(将禁用所有对set_trace的调用).这是一个更好的解决方案.我们定义一个包装pdb的模块.在其中,set_trace是一个可调用对象,维护一个被禁用的调用者列表(由filename / line-number标识).
# mypdb.pyimport inspectimport systry: import ipdb as PDBexcept importError: import pdb as PDBclass SetTraceWrapper(object): def __init__(self): self.callers_Disabled = set() self.cur_caller = None def __call__(self): self.cur_caller = self.get_caller_ID() if self.cur_caller in self.callers_Disabled: # already Disabled for caller #print 'set_trace SKIPPED for %s' % ( self.cur_caller,) return #print 'set_trace BREAKING for %s' % ( self.cur_caller,) try: PDB.set_trace(sys._getframe().f_back) except TypeError: PDB.set_trace() def disable_current(self): #print 'set_trace disABliNG %s' % ( self.cur_caller,) self.callers_Disabled.add(self.cur_caller) def get_caller_ID(self,levels_up = 1): f = inspect.stack()[levels_up + 1] return ( f[1],f[2] ) # filename and line numberset_trace = SetTraceWrapper()
在您的代码中,请确保使用包装器:
import mypdb as pdb; pdb.set_trace()
如果要禁用当前的set_trace-calling-line,请执行以下 *** 作:
pdb.set_trace.disable_current()
笔记:
>我个人更喜欢ipdb而不是pdb>使用pdb时,由于实际调用pdb.set_trace的函数位于包装器中,因此当前帧在断开时将在其中. up命令可以获得你想要的帧.如果使用ipdb,则不会发生这种情况(包装器中的实现确保在正确的位置中断).>当使用ipdb时,我发现它不一致地报告调用者帧行号.这意味着第一次执行pdb.set_trace.disable_current()时,它可能不成立.如果下次再次破坏,请再次执行 – 第二次持续.>通常,拥有自己的pdb包装器对其他事情也很有用.我有自己的set_trace包装器,如果不是sys.stdout.isatty(如果进程没有连接到终端,也不想将stdout重定向到文件/管道,你永远不想破坏).也就是说,拥有自己的pdb包装器并调用其set_trace而不是pdb是一个很好的做法.
总结以上是内存溢出为你收集整理的python – 如何在使用pdb时忽略一行?全部内容,希望文章能够帮你解决python – 如何在使用pdb时忽略一行?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)