python - 如何获取异常时栈中的数值
问题描述
假设有这样一段代码:
try: a = 1 b = 0 c = a / bexcept Exception as e: print(e)
现在想在异常发生时获取到异常发生前每个变量的数值,即获取到a=1,b=0这样的结果。
问题解答
回答1:inspect.currentframe
>>> import inspect>>> a=1;b=0;a/bTraceback (most recent call last): File '<pyshell#10>', line 1, in <module> a=1;b=0;a/bZeropisionError: pision by zero>>> f=inspect.currentframe()>>> f.f_globals[’a’]1>>> f.f_globals[’b’]0>>> 回答2:
这个python应该是没法主动实现的, 因为如果有这样的方法, 在多层调用时, 出现了异常, 一层层记录相应的数据然后再返回, 那么这很可能会导致内存方面的问题; 而且在出现异常前, 虚拟机也不知道你会问题, 就好像你上面的除零异常, 是在运行 a/b => 1/0, 在PyIntobject的i_pmod函数代码实现中, 判断出除数为0, 直接触发异常, 然后一层层栈返回, 告诉用户出现异常, 在try_block中也并没有记录符号的值相关的代码, 所以顶多人为在except中, 做出更加精细, 人性化的输出了
回答3:使用ipython 把pdb打开,可以做到报哪一行出错!
ZeropisionError: integer pision or modulo by zero> <ipython-input-4-a5ac4c0f15ad>(4)<module>() 1 2 a = 1 3 b = 0----> 4 c = a / bipdb> 回答4:
pdb
加入代码如下:
#!/usr/bin/env python# encoding: utf-8try: a = 1 b = 0 c = a / bexcept Exception as e: import pdb; pdb.set_trace() # <-- 加入断点 print(e)
执行如下:
❯ python sf.py> /Users/caimaoy/tmp/sf.py(10)<module>()-> print(e)(Pdb) ll 1 #!/usr/bin/env python 2 # encoding: utf-8 3 4 try: 5 a = 1 6 b = 0 7 c = a / b 8 except Exception as e: 9 import pdb; pdb.set_trace() 10 -> print(e)(Pdb) p a1(Pdb) p b0(Pdb)
相关文章:
1. angular.js - ionic 弹窗样式2. vue.js - weex scroller搭配refresh在android平台上拉会触发refresh3. javascript - h5上的手机号默认没有识别4. javascript - 在html中写了个<video>视频,浏览器却是一片空白为什么呢?360浏览器?5. javascript - 新建js文件时如何自动地加上"use strict"?6. 【加急】请问webarchive格式转换html怎么做7. css - div display: inline-block; 置中?8. css3 - Firefox 字号相对IE、Chrome更大,如何在CSS中统一?9. javascript - ajax中的 textStatus 报错为 parsererror?10. 如何解决docker宿主机无法访问容器中的服务?