python - 如何獲取異常時棧中的數(shù)值
問題描述
假設(shè)有這樣一段代碼:
try: a = 1 b = 0 c = a / bexcept Exception as e: print(e)
現(xiàn)在想在異常發(fā)生時獲取到異常發(fā)生前每個變量的數(shù)值,即獲取到a=1,b=0這樣的結(jié)果。
問題解答
回答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應(yīng)該是沒法主動實(shí)現(xiàn)的, 因為如果有這樣的方法, 在多層調(diào)用時, 出現(xiàn)了異常, 一層層記錄相應(yīng)的數(shù)據(jù)然后再返回, 那么這很可能會導(dǎo)致內(nèi)存方面的問題; 而且在出現(xiàn)異常前, 虛擬機(jī)也不知道你會問題, 就好像你上面的除零異常, 是在運(yùn)行 a/b => 1/0, 在PyIntobject的i_pmod函數(shù)代碼實(shí)現(xiàn)中, 判斷出除數(shù)為0, 直接觸發(fā)異常, 然后一層層棧返回, 告訴用戶出現(xiàn)異常, 在try_block中也并沒有記錄符號的值相關(guān)的代碼, 所以頂多人為在except中, 做出更加精細(xì), 人性化的輸出了
回答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() # <-- 加入斷點(diǎn) print(e)
執(zhí)行如下:
? 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)
相關(guān)文章:
1. css3 - 求教CSS圖標(biāo)庫的寫法,也就是先做雪碧圖,然后寫一個css表,用的時候直接用class就可以了2. 百度地圖api - Android百度地圖SDK,MapView上層按鈕可見卻不可觸,怎么解決?3. html - 前端大牛都頂一下!CSS鼠標(biāo)樣式問題,如圖所示4. javascript - es6擴(kuò)展運(yùn)算符...的問題5. 網(wǎng)頁爬蟲 - python爬蟲用BeautifulSoup爬取<s>元素并寫入字典,但某些div下沒有這一元素,導(dǎo)致自動寫入下一條,如何解決?6. node.js - 在nodejs環(huán)境中如何配置webhook以實(shí)現(xiàn)hexo博客的自動更新?7. html5 - canvas中的mousedrag事件,為什么鼠標(biāo)拖出canvas,然后再次移入canvas,drag事件還觸發(fā)8. javascript - jquery怎么給select option一個點(diǎn)擊時觸發(fā)的事件,如圖 如果選擇自定義觸發(fā)一個時間?9. 新入手layuiadmin,部署到tp中。想用php自已寫一個后臺管理系統(tǒng)。10. mysql 獲取時間函數(shù)unix_timestamp 問題?
