在Python中,如何从方法中打印当前调用堆栈(用于调试目的)。
当前回答
安装检查
pip3 install inspect-it --user
Code
import inspect;print(*['{:40}| {}:{}\n'.format(x.function, x.filename, x.lineno) for x in inspect.stack()])
你可以对这一行做一个代码片段
它将向您显示带有文件名和行号的函数调用堆栈列表
列出从开始到放这一行的位置
其他回答
下面是一个通过traceback模块获取堆栈并打印的例子:
import traceback
def f():
g()
def g():
for line in traceback.format_stack():
print(line.strip())
f()
# Prints:
# File "so-stack.py", line 10, in <module>
# f()
# File "so-stack.py", line 4, in f
# g()
# File "so-stack.py", line 7, in g
# for line in traceback.format_stack():
如果你真的只想打印堆栈到stderr,你可以使用:
traceback.print_stack()
或者打印到stdout(如果想保持重定向输出在一起很有用),使用:
traceback.print_stack(file=sys.stdout)
但是通过traceback.format_stack()获取它可以让你对它做任何你喜欢的事情。
import traceback
traceback.print_stack()
安装检查
pip3 install inspect-it --user
Code
import inspect;print(*['{:40}| {}:{}\n'.format(x.function, x.filename, x.lineno) for x in inspect.stack()])
你可以对这一行做一个代码片段
它将向您显示带有文件名和行号的函数调用堆栈列表
列出从开始到放这一行的位置
对于那些在使用pdb时需要打印调用堆栈的人,就这样做吧
(Pdb) where
Inspect.stack()返回当前堆栈,而不是异常回溯:
import inspect
print inspect.stack()
有关log_stack实用函数,请参阅https://gist.github.com/FredLoney/5454553。
推荐文章
- 省略[…]意思是在一个列表里?
- 为什么我得到“'str'对象没有属性'读取'”当尝试使用' json。载入字符串?
- 不区分大小写的列表排序,没有降低结果?
- 排序后的语法(key=lambda:…)
- 在烧瓶中返回HTTP状态代码201
- 使用python创建一个简单的XML文件
- APT命令行界面式的yes/no输入?
- 如何打印出状态栏和百分比?
- 在Python中获取大文件的MD5哈希值
- 在Python格式字符串中%s是什么意思?
- 如何循环通过所有但最后一项的列表?
- python用什么方法避免默认参数为空列表?
- ValueError: numpy。Ndarray大小改变,可能表示二进制不兼容。期望从C头得到88,从PyObject得到80
- Anaconda /conda -安装特定的软件包版本
- 我在哪里调用Keras的BatchNormalization函数?