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

首頁 > 編程 > Python > 正文

關于Python中異常(Exception)的匯總

2019-11-25 16:23:56
字體:
來源:轉載
供稿:網友

前言

Exception類是常用的異常類,該類包括StandardError,StopIteration, GeneratorExit, Warning等異常類。python中的異常使用繼承結構創建,可以在異常處理程序中捕獲基類異常,也可以捕獲各種子類異常,python中使用try...except語句捕獲異常,異常子句定義在try子句后面。

Python中的異常處理

異常處理的語句結構

try: <statements>  #運行try語句塊,并試圖捕獲異常except <name1>: <statements>  #如果name1異常發現,那么執行該語句塊。except (name2, name3): <statements>  #如果元組內的任意異常發生,那么捕獲它except <name4> as <variable>: <statements>  #如果name4異常發生,那么進入該語句塊,并把異常實例命名為variableexcept: <statements>  #發生了以上所有列出的異常之外的異常else:<statements>   #如果沒有異常發生,那么執行該語句塊finally: <statement>   #無論是否有異常發生,均會執行該語句塊。

說明

  • else和finally是可選的,可能會有0個或多個except,但是,如果出現一個else的話,必須有至少一個except。
  • 不管你如何指定異常,異常總是通過實例對象來識別,并且大多數時候在任意給定的時刻激活。一旦異常在程序中某處由一條except子句捕獲,它就死掉了,除非由另一個raise語句或錯誤重新引發它。

raise語句

raise語句用來手動拋出一個異常,有下面幾種調用格式:

  • raise #可以在raise語句之前創建該實例或者在raise語句中創建。
  • raise #Python會隱式地創建類的實例
  • raise name(value) #拋出異常的同時,提供額外信息value
  • raise # 把最近一次產生的異常重新拋出來
  • raise exception from E

例如:

拋出帶有額外信息的ValueError: raise ValueError('we can only accept positive values')

當使用from的時候,第二個表達式指定了另一個異常類或實例,它會附加到引發異常的__cause__屬性。如果引發的異常沒有捕獲,Python把異常也作為標準出錯消息的一部分打印出來:

比如下面的代碼:

try: 1/0except Exception as E: raise TypeError('bad input') from E

執行的結果如下:

Traceback (most recent call last): File "hh.py", line 2, in <module> 1/0ZeroDivisionError: division by zeroThe above exception was the direct cause of the following exception:Traceback (most recent call last): File "hh.py", line 4, in <module> raise TypeError('bad input') from ETypeError: bad input

assert語句

assert主要用來做斷言,通常用在單元測試中較多,到時候再做介紹。

with...as語句

with語句支持更豐富的基于對象的協議,可以為代碼塊定義支持進入和離開動作。

with語句對應的環境管理協議要求如下:

  • 環境管理器必須有__enter____exit__方法。

       __enter__方法會在初始化的時候運行,如果存在ass子在, __enter__函數的返回值會賦值給as子句中的變量,否則,直接丟棄。

       代碼塊中嵌套的代碼會執行。

       如果with代碼塊引發異常, __exit__(type,value,traceback)方法就會被調用(帶有異常細節)。這些也是由 sys.exc_info返回的相同值.如果此方法返回值為假,則異常會重新引發。否則,異常會終止。正常 情況下異常是應該被重新引發,這樣的話才能傳遞到with語句之外。

       如果with代碼塊沒有引發異常, __exit__方法依然會被調用,其type、value以及traceback參數都會以None傳遞。

下面為一個簡單的自定義的上下文管理類。

class Block: def __enter__(self):  print('entering to the block')  return self  def prt(self, args):  print('this is the block we do %s' % args) def __exit__(self,exc_type, exc_value, exc_tb):  if exc_type is None:   print('exit normally without exception')  else:   print('found exception: %s, and detailed info is %s' % (exc_type, exc_value))  return Falsewith Block() as b: b.prt('actual work!') raise ValueError('wrong')

如果注銷到上面的raise語句,那么會正常退出。

在沒有注銷掉該raise語句的情況下,運行結果如下:

entering to the blockthis is the block we do actual work!found exception: <class 'ValueError'>, and detailed info is wrongTraceback (most recent call last): File "hh.py", line 18, in <module> raise ValueError('wrong')ValueError: wrong

異常處理器

如果發生異常,那么通過調用sys.exc_info()函數,可以返回包含3個元素的元組。 第一個元素就是引發異常類,而第二個是實際引發的實例,第三個元素traceback對象,代表異常最初發生時調用的堆棧。如果一切正常,那么會返回3個None。

Python的Builtins模塊中定義的Exception

|Exception Name|Description||BaseException|Root class for all exceptions|| SystemExit|Request termination of Python interpreter||KeyboardInterrupt|User interrupted execution (usually by pressing Ctrl+C)||Exception|Root class for regular exceptions|| StopIteration|Iteration has no further values|| GeneratorExit|Exception sent to generator to tell it to quit|| SystemExit|Request termination of Python interpreter|| StandardError|Base class for all standard built-in exceptions||  ArithmeticError|Base class for all numeric calculation errors||   FloatingPointError|Error in floating point calculation||   OverflowError|Calculation exceeded maximum limit for numerical type||   ZeroDivisionError|Division (or modulus) by zero error (all numeric types)||  AssertionError|Failure of assert statement||  AttributeError|No such object attribute||  EOFError|End-of-file marker reached without input from built-in||  EnvironmentError|Base class for operating system environment errors||   IOError|Failure of input/output operation||   OSError|Operating system error||    WindowsError|MS Windows system call failure||    ImportError|Failure to import module or object||    KeyboardInterrupt|User interrupted execution (usually by pressing Ctrl+C)||   LookupError|Base class for invalid data lookup errors||    IndexError|No such index in sequence||    KeyError|No such key in mapping||   MemoryError|Out-of-memory error (non-fatal to Python interpreter)||   NameError|Undeclared/uninitialized object(non-attribute)||    UnboundLocalError|Access of an uninitialized local variable||   ReferenceError|Weak reference tried to access a garbage collected object||   RuntimeError|Generic default error during execution||    NotImplementedError|Unimplemented method||   SyntaxError|Error in Python syntax||    IndentationError|Improper indentation||     TabErrorg|Improper mixture of TABs and spaces||   SystemError|Generic interpreter system error||   TypeError|Invalid operation for type||   ValueError|Invalid argument given||    UnicodeError|Unicode-related error||     UnicodeDecodeError|Unicode error during decoding||     UnicodeEncodeError|Unicode error during encoding||     UnicodeTranslate Error|Unicode error during translation||  Warning|Root class for all warnings||   DeprecationWarning|Warning about deprecated features||   FutureWarning|Warning about constructs that will change semantically in the future||   OverflowWarning|Old warning for auto-long upgrade||   PendingDeprecation Warning|Warning about features that will be deprecated in the future||   RuntimeWarning|Warning about dubious runtime behavior||   SyntaxWarning|Warning about dubious syntax||   UserWarning|Warning generated by user code|

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 慈利县| 县级市| 梁平县| 五家渠市| 兰考县| 和平县| 孟津县| 镶黄旗| 曲松县| 通渭县| 阳山县| 古浪县| 通河县| 垣曲县| 曲麻莱县| 两当县| 道孚县| 神池县| 布拖县| 台前县| 玉田县| 贡觉县| 伽师县| 夏邑县| 淅川县| 重庆市| 永新县| 花莲市| 穆棱市| 西盟| 西丰县| 固安县| 正蓝旗| 万宁市| 车致| 恩施市| 科技| 西宁市| 玛沁县| 民乐县| 苍山县|