在Python中,最好的debug方式是什么?毫无疑问,是print,但是print有时候显得有点笨拙,比如考虑下面的代码:
我们通过print输出a的值,方便debug,但是如果你的代码里有十几个变量需要这样的方式来查看值,那你一定会搞不清谁对应谁,所以,我们还需要什么呢?毫无疑问,变量的名字!
最简单的方法是,在输出变量的同时,输出变量名,比如将“print a"改为"print 'a : ', a”。每一个都要这样写,是不是很不爽?有没有一种方法,可以自动侦测变量名?
有,当然有,实际上,Python代码中所有的信息在编译之后都会被存储起来,这样,你不仅能获得Python运行时的动态信息,而且还能获得Python代码中的静态信息,变量名不就是一静态信息么。只需要利用Python的frame对象和code对象,就能完成一切魔法。
下面在输出变量值时自动获取变量名的一种解决方案:
def
f(value):
a = value
print a
f( 3 )
a = value
print a
f( 3 )
我们通过print输出a的值,方便debug,但是如果你的代码里有十几个变量需要这样的方式来查看值,那你一定会搞不清谁对应谁,所以,我们还需要什么呢?毫无疑问,变量的名字!
最简单的方法是,在输出变量的同时,输出变量名,比如将“print a"改为"print 'a : ', a”。每一个都要这样写,是不是很不爽?有没有一种方法,可以自动侦测变量名?
有,当然有,实际上,Python代码中所有的信息在编译之后都会被存储起来,这样,你不仅能获得Python运行时的动态信息,而且还能获得Python代码中的静态信息,变量名不就是一静态信息么。只需要利用Python的frame对象和code对象,就能完成一切魔法。
下面在输出变量值时自动获取变量名的一种解决方案:
import
sys
import dis
import StringIO
def parse_bytecodes(bufvalue):
var_names = []
bytecodes = <
import dis
import StringIO
def parse_bytecodes(bufvalue):
var_names = []
bytecodes = <