国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python使用try except處理程序異常的三種常用方法分析

2020-01-04 14:35:11
字體:
來源:轉載
供稿:網友

本文實例講述了Python使用try except處理程序異常的三種常用方法。分享給大家供大家參考,具體如下:

如果你在寫python程序時遇到異常后想進行如下處理的話,一般用try來處理異常,假設有下面的一段程序:

try:  語句1  語句2  .  .  語句Nexcept .........:  do something .......

但是你并不知道"語句1至語句N"在執(zhí)行會出什么樣的異常,但你還要做異常處理,且想把出現(xiàn)的異常打印出來,并不停止程序的運行,所以在"except ......"這句應怎樣來寫呢?

總結了一下3個方法:

方法一:捕獲所有異常

try:  a=b  b=cexcept Exception,e:  print Exception,":",e

測試結果:

<type 'exceptions.Exception'> : name 'b' is not defined

方法二:采用traceback模塊查看異常

#引入python中的traceback模塊,跟蹤錯誤import tracebacktry:  a=b  b=cexcept:  traceback.print_exc()

方法三:采用sys模塊回溯最后的異常

#引入sys模塊import systry:  a=b  b=cexcept:  info=sys.exc_info()  print info[0],":",info[1]

運行結果:

<type 'exceptions.NameError'> : name 'b' is not defined

但是,如果你還想把這些異常保存到一個日志文件中,來分析這些異常,那么請看下面的方法:

把 traceback.print_exc() 打印在屏幕上的信息保存到一個文本文件中

import tracebacktry:  a=b  b=cexcept:  f=open("c:/log.txt",'a')  traceback.print_exc(file=f)  f.flush()  f.close()

此時C盤根目錄下生成一個log.txt文件,內容如下:

Traceback (most recent call last):
  File "C:/py/jb51PyDemo/src/Demo/test.py", line 3, in <module>
    a=b
NameError: name 'b' is not defined

希望本文所述對大家Python程序設計有所幫助。


注:相關教程知識閱讀請移步到python教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 额敏县| 绩溪县| 昌平区| 兰考县| 怀柔区| 洱源县| 溧阳市| 平山县| 长沙市| 金堂县| 玛沁县| 大城县| 内丘县| 汶川县| 沂水县| 凤阳县| 当雄县| 祥云县| 如东县| 宁国市| 元谋县| 吕梁市| 海林市| 隆林| 贵溪市| 得荣县| 屯留县| 满城县| 江华| 温泉县| 方山县| 贵港市| 房产| 塔河县| 常德市| 西乌珠穆沁旗| 瓮安县| 吴桥县| 阿城市| 分宜县| 大悟县|