Python 獲取異常(Exception)信息的幾種方法
異常信息的獲取對(duì)于程序的調(diào)試非常重要,可以有助于快速定位有錯(cuò)誤程序語句的位置。下面介紹幾種 Python 中獲取異常信息的方法,這里獲取異常(Exception)信息采用 try…except… 程序結(jié)構(gòu)。
如下所示:
try: print(x) except Exception as e: print(e)
1. str(e)
返回字符串類型,只給出異常信息,不包括異常信息的類型,如:
try: print(x) except Exception as e: print(str(e))
打印結(jié)果:
name 'x' is not defined
2. repr(e)
給出較全的異常信息,包括異常信息的類型,如:
try: print(x) except Exception as e: print(repr(e))
打印結(jié)果:
NameError("name 'x' is not defined",)
一般情況下,當(dāng)我們知道異常信息類型后,可以對(duì)異常進(jìn)行更精確的捕獲,如:
try: print(x) except NameError: print('Exception Type: NameError') except Exception as e: print(str(e))
3. 采用 traceback 模塊
需要導(dǎo)入 traceback 模塊,此時(shí)獲取的信息最全,與 Python 命令行運(yùn)行程序出現(xiàn)錯(cuò)誤信息一致。
用法:使用 traceback.print_exc() 或 traceback.format_exc() 打印錯(cuò)誤。
區(qū)別:traceback.print_exc() 直接打印錯(cuò)誤,traceback.format_exc() 返回字符串。
示例如下:
import traceback try: print(x) except Exception as e: traceback.print_exc()
等價(jià)于:
import traceback try: print(x) except Exception as e: msg = traceback.format_exc() print(msg)
打印結(jié)果都是:
Traceback (most recent call last): File "E:/study/python/get_exception.py", line 4, in <module> print(x) NameError: name 'x' is not defined
traceback.print_exc() 還可以接受 file 參數(shù)直接寫入到一個(gè)文件。比如:
# 寫入到 tb.txt 文件中 traceback.print_exc(file=open('tb.txt','w+'))
以上就是Python 獲取異常(Exception)信息的幾種方法的詳細(xì)內(nèi)容,更多關(guān)于python 獲取異常信息的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python?網(wǎng)易易盾滑塊驗(yàn)證功能的實(shí)現(xiàn)
這篇文章主要介紹了Python?網(wǎng)易易盾滑塊驗(yàn)證,主要是借助之前寫阿里云盾滑塊和極驗(yàn)滑塊的經(jīng)驗(yàn)寫的本文,通過使用selenium請(qǐng)求url,并觸發(fā)滑塊驗(yàn)證,需要的朋友可以參考下2022-05-05Jinja2實(shí)現(xiàn)模板渲染與訪問對(duì)象屬性流程詳解
要了解jinja2,那么需要先理解模板的概念。模板在Python的web開發(fā)中廣泛使用,它能夠有效的將業(yè)務(wù)邏輯和頁面邏輯分開,使代碼可讀性增強(qiáng),并且更加容易理解和維護(hù)。模板簡單來說就是一個(gè)其中包含占位變量表示動(dòng)態(tài)部分的文,模板文件在經(jīng)過動(dòng)態(tài)賦值后,返回給用戶2023-03-03python中24小時(shí)制轉(zhuǎn)換為12小時(shí)制的方法
最近需要實(shí)現(xiàn)一個(gè)需求,求用戶輸入24小時(shí)制的時(shí)間,然后顯示12小時(shí)制的時(shí)間。具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06