Python異常繼承關系和自定義異常實現(xiàn)代碼實例
這篇文章主要介紹了Python異常繼承關系和自定義異常實現(xiàn)代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
主要介紹 python 中異常的繼承關系,及如何自定義異常
1. 異常的繼承關系
BaseException # 所有異常的基類 +-- SystemExit # 解釋器請求退出 +-- KeyboardInterrupt 用戶中斷執(zhí)行(通常是輸入^C) +-- GeneratorExit # 生成器(generator)發(fā)生異常來通知退出 +-- Exception # 常規(guī)異常的基類 +-- StopIteration # 迭代器沒有更多的值 +-- StandardError # 標準錯誤 | +-- BufferError | +-- ArithmeticError | | +-- FloatingPointError | | +-- OverflowError | | +-- ZeroDivisionError | +-- AssertionError | +-- AttributeError | +-- EnvironmentError | | +-- IOError | | +-- OSError | | +-- WindowsError (Windows) | | +-- VMSError (VMS) | +-- EOFError | +-- ImportError | +-- LookupError | | +-- IndexError | | +-- KeyError | +-- MemoryError | +-- NameError | | +-- UnboundLocalError | +-- ReferenceError | +-- RuntimeError | | +-- NotImplementedError | +-- SyntaxError | | +-- IndentationError | | +-- TabError | +-- SystemError | +-- TypeError | +-- ValueError | +-- UnicodeError | +-- UnicodeDecodeError | +-- UnicodeEncodeError | +-- UnicodeTranslateError +-- Warning +-- DeprecationWarning +-- PendingDeprecationWarning +-- RuntimeWarning +-- SyntaxWarning +-- UserWarning +-- FutureWarnin +-- ImportWarnin +-- UnicodeWarnin +-- BytesWarning
2. 自定義異常
#自定義異常 需要繼承Exception class MyException(Exception): def __init__(self, *args): self.args = args if __name__ == '__main__': try: raise MyException("自定義異常") except MyException as e: print e
3. 異常捕獲
# 示例 str1 = 'abc' try: int(str1) except IndexError as e: print e except KeyError as e: print e except ValueError as e: print e else: print 'try內(nèi)正常處理' finally: print '無論異常與否,都會執(zhí)行我'
4. 主動觸發(fā)異常
# raise xxx def test_zero(num): try: if num == 0: raise ValueError('參數(shù)錯誤') return num except Exception as e: print e test_zero(0)
5. 采用traceback模塊查看異常
異常發(fā)生時,Python 能“記住”引發(fā)的異常以及程序的當前狀態(tài)。
Python 維護著traceback(跟蹤)對象,其中含有異常發(fā)生時與函數(shù)調(diào)用堆棧有關的信息。
異??赡茉谝幌盗星短纵^深的函數(shù)調(diào)用中引發(fā)。
程序調(diào)用每個函數(shù)時,Python 會在“函數(shù)調(diào)用堆?!钡钠鹗继幉迦牒瘮?shù)名。一旦異常被引發(fā),Python 會搜索一個相應的異常處理程序。如果當前函數(shù)中沒有異常處理程序,當前函數(shù)會終止執(zhí)行,Python 會搜索當前函數(shù)的調(diào)用函數(shù),并以此類推,直到發(fā)現(xiàn)匹配的異常處理程序,或者Python 抵達主程序為止。這一查找合適的異常處理程序的過程稱為“堆棧輾轉(zhuǎn)開解”(StackUnwinding)。
解釋器一方面維護著與放置堆棧中的函數(shù)有關的信息,另一方面也維護著與已從堆棧中“輾轉(zhuǎn)開解”的函數(shù)有關的信息。
#示例 def div(num1, num2): try: result = num1/num2 return result except Exception as e: traceback.print_exc() print div(1, 0)
#執(zhí)行結(jié)果 Traceback (most recent call last): None File "F:/Technology-20161005/python/python_project/demo/exceptiondemo/exceptiondemo.py", line 17, in div result = num1/num2 ZeroDivisionError: integer division or modulo by zero
# 可以將異常信息寫到文件中 traceback.print_exc(file=open('1.txt','w+'))
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Python數(shù)字圖像處理之霍夫線變換實現(xiàn)詳解
這篇文章主要介紹了Python數(shù)字圖像處理之霍夫線變換實現(xiàn)詳解,具有一定借鑒價值,需要的朋友可以參考下2018-01-01利用Python制作動態(tài)排名圖的實現(xiàn)代碼
這篇文章主要介紹了利用Python制作動態(tài)排名圖的實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04使用python如何將數(shù)據(jù)集劃分為訓練集、驗證集和測試集
這篇文章主要介紹了使用python如何將數(shù)據(jù)集劃分為訓練集、驗證集和測試集問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-09-09