久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

Python新手學習raise用法

瀏覽:112日期:2022-07-23 10:09:34

當程序出現錯誤時,系統會自動引發異常。除此之外,Python 也允許程序自行引發異常,自行引發異常使用 raise 語句來完成。

很多時候,系統是否要引發異常,可能需要根據應用的業務需求來決定,如果程序中的數據、執行與既定的業務需求不符,這就是一種異常。由于與業務需求不符而產生的異常,必須由程序員來決定引發,系統無法引發這種異常。

如果需要在程序中自行引發異常,則應使用 raise 語句。raise 語句有如下三種常用的用法:

raise:單獨一個 raise。該語句引發當前上下文中捕獲的異常(比如在 except 塊中),或默認引發 RuntimeError 異常。 raise 異常類:raise 后帶一個異常類。該語句引發指定異常類的默認實例。 raise 異常對象:引發指定的異常對象。

上面三種用法最終都是要引發一個異常實例(即使指定的是異常類,實際上也是引發該類的默認實例),raise 語句每次只能引發一個異常實例。

可以利用 raise 語句再次改寫前面五子棋游戲中處理用戶輸入的代碼:

try : #將用戶輸入的字符串以逗號( ,)作為分隔符,分隔成兩個字符串 x_str, y_str = inputStr.split(sep =',') #如果要下棋的點不為空 if board[int(y_str) - 1] [int(x_str) - 1] != '+': #引發默認的RuntimeError異常 raise #把對應的列表元素賦為”●” board [int(y_str) - 1] [int(x_str) - 1] = ”●”except Exception as e: print (type(e)) inputStr = input('您輸入的坐標不合法,請重新輸入,下棋坐標應以x,y 的格式n') continue

上面程序中第 7 行代碼使用 raise 語句來自行引發異常,程序認為當用戶試圖向一個已有棋子的坐標點下棋時就是異常。當 Python 解釋器接收到開發者自行引發的異常時,同樣會中止當前的執行流,跳到該異常對應的 except 塊,由該 except 塊來處理該異常。也就是說,不管是系統自動引發的異常,還是程序員于動引發的異常,Python 解釋器對異常的處理沒有任何差別。

即使是用戶自行引發的異常,也可以使用 try except 來捕獲它。當然也可以不管它,讓該異常向上(先調用者)傳播,如果該異常傳到 Python 解釋器,那么程序就會中止。

下面示例示范了處理用戶引發異常的兩種方式:

def main(): try: # 使用try...except來捕捉異常 # 此時即使程序出現異常,也不會傳播給main函數 mtd(3) except Exception as e: print(’程序出現異常:’, e) # 不使用try...except捕捉異常,異常會傳播出來導致程序中止 mtd(3)def mtd(a): if a > 0: raise ValueError('a的值大于0,不符合要求')main()

從上面程序可以看到,程序既可在調用 mtd(3) 時使用 try except 來捕獲異常,這樣該異常將會被 except 塊捕獲,不會傳播給調用它的函數;也可直接調用 mtd(3),這樣該函數的異常就會直接傳播給它的調用函數,如果該函數也不處理該異常,就會導致程序中止。

運行上面程序,可以看到如下輸出結果:

程序出現異常: a的值大于0,不符合要求Traceback (most recent call last):File 'C:UsersmengmaDesktop1.py', line 13, in <module>main()File 'C:UsersmengmaDesktop1.py', line 9, in mainmtd(3)File 'C:UsersmengmaDesktop1.py', line 12, in mtdraise ValueError('a的值大于0,不符合要求')ValueError: a的值大于0,不符合要求

上面第一行輸出是第一次調用 mtd (3) 的結果,該方法引發的異常被 except 塊捕獲并處理。后面的大段輸出則是第二次調用 mtd(3) 的結果,由于該異常沒有被 except 塊捕獲,因此該異常一直向上傳播,直到傳給 Python 解釋器導致程序中止。

第二次調用 mtd(3) 引發的以“File”開頭的三行輸出,其實顯示的就是異常的傳播軌跡信息。也就是說,如果程序不對異常進行處理,Python 默認會在控制臺輸出異常的傳播軌跡信息。

自定義異常類

很多時候,程序可選擇引發自定義異常,因為異常的類名通常也包含了該異常的有用信息。所以在引發異常時,應該選擇合適的異常類,從而可以明確地描述該異常情況。在這種情形下,應用程序常常需要引發自定義異常。

用戶自定義異常都應該繼承 Exception 基類或 Exception 的子類,在自定義異常類時基本不需要書寫更多的代碼,只要指定自定義異常類的父類即可。

下面程序創建了一個自定義異常類(程序一):

class AuctionException(Exception): pass

上面程序創建了 AuctionException 異常類,該異常類不需要類體定義,因此使用 pass 語句作為占位符即可。

在大部分情況下,創建自定義異常類都可采用與程序一相似的代碼來完成,只需改變 AuctionException 異常的類名即可,讓該異常的類名可以準確地描述該異常。

except 和 raise 同時使用

在實際應用中對異常可能需要更復雜的處理方式。當一個異常出現時,單靠某個方法無法完全處理該異常,必須由幾個方法協作才可完全處理該異常。也就是說,在異常出現的當前方法中,程序只對異常進行部分處理,還有些處理需要在該方法的調用者中才能完成,所以應該再次引發異常,讓該方法的調用者也能捕獲到異常。

為了實現這種通過多個方法協作處理同一個異常的情形,可以在 except 塊中結合 raise 語句來完成。如下程序示范了except 和 raise 同時使用的方法:

class AuctionException(Exception): passclass AuctionTest: def __init__(self, init_price): self.init_price = init_price def bid(self, bid_price): d = 0.0 try: d = float(bid_price) except Exception as e: # 此處只是簡單地打印異常信息 print('轉換出異常:', e) # 再次引發自定義異常 raise AuctionException('競拍價必須是數值,不能包含其他字符!') # ① raise AuctionException(e) if self.init_price > d: raise AuctionException('競拍價比起拍價低,不允許競拍!') initPrice = ddef main(): at = AuctionTest(20.4) try: at.bid('df') except AuctionException as ae: # 再次捕獲到bid()方法中的異常,并對該異常進行處理 print(’main函數捕捉的異常:’, ae)main()

上面程序中 9~13 行代碼對應的 except 塊捕獲到異常后,系統打印了該異常的字符串信息,接著引發一個 AuctionException 異常,通知該方法的調用者再次處理該 AuctionException 異常。所以程序中的 main() 函數,也就是 bid() 方法的調用者還可以再次捕獲 AuctionException 異常,井將該異常的詳細描述信息打印出來。

這種 except 和 raise 結合使用的情況在實際應用中非常常用。實際應用對異常的處理通常分成兩個部分:

應用后臺需要通過日志來記錄異常發生的詳細情況;

應用還需要根據異常向應用使用者傳達某種提示;

在這種情形下,所有異常都需要兩個方法共同完成,也就必須將 except 和 raise 結合使用。

如果程序需要將原始異常的詳細信息直接傳播出去,Python 也允許用自定義異常對原始異常進行包裝,只要將上面 ① 號代碼改為如下形式即可:

raise AuctionException(e)

raise 不需要參數

正如前面所看到的,在使用 raise 語句時可以不帶參數,此時 raise 語句處于 except 塊中,它將會自動引發當前上下文激活的異常;否則,通常默認引發 RuntimeError 異常。

例如,將上面程序改為如下形式:

class AuctionException(Exception): passclass AuctionTest: def __init__(self, init_price): self.init_price = init_price def bid(self, bid_price): d = 0.0 try: d = float(bid_price) except Exception as e: # 此處只是簡單地打印異常信息 print('轉換出異常:', e) # 再次引發自定義異常 raise if self.init_price > d: raise AuctionException('競拍價比起拍價低,不允許競拍!') initPrice = ddef main(): at = AuctionTest(20.4) try: at.bid('df') except AuctionException as ae: # 再次捕獲到bid()方法中的異常,并對該異常進行處理 print(’main函數捕捉的異常:’, ae)main()

正如從 13 行代碼所看到的,此時程序在 except 塊中只是簡單地使用 raise 語句來引發異常,那么該 raise 語句將會再次引發該 except 塊所捕獲的異常。運行該程序,可以看到如下輸出結果:

轉換出異常: could not convert string to float: ’df’

main 函數捕獲的異常:<class ’ValueError’>

知識點補充:

演示raise用法

try: s = None if s is None: print 's 是空對象' raise NameError #如果引發NameError異常,后面的代碼將不能執行 print len(s) #這句不會執行,但是后面的except還是會走到except TypeError: print '空對象沒有長度' s = Noneif s is None: raise NameError print ’is here?’ #如果不使用try......except這種形式,那么直接拋出異常,不會執行到這里

觸發異常

我們可以使用raise語句自己觸發異常

raise語法格式如下:

raise [Exception [, args [, traceback]]]

語句中 Exception 是異常的類型(例如,NameError)參數標準異常中任一種,args 是自已提供的異常參數。

最后一個參數是可選的(在實踐中很少使用),如果存在,是跟蹤異常對象。到此這篇關于Python新手學習raise用法的文章就介紹到這了,更多相關Python中raise用法內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 欧美日韩激情在线一区二区三区 | 91精品国产综合久久久久久丝袜 | 国产日产精品一区二区三区四区 | 色综合天天综合网国产成人网 | 在线欧美亚洲 | 国产精品亚洲一区二区三区在线 | 精品欧美激情在线观看 | 伊人精品在线 | 国产真实乱全部视频 | 日韩三级黄 | 日韩精品一区二区在线观看 | 国产精品手机在线 | 亚洲乱码国产乱码精品精的特点 | 99精品视频一区二区三区 | 黑人精品 | 午夜精品成人一区二区 | 欧美xxxx做受欧美 | 禁果av一区二区三区 | 九九热精 | 色吊丝在线 | 日韩欧美一区二区三区久久婷婷 | 亚洲福利一区 | 亚洲乱码一区二区三区在线观看 | 三区免费视频 | 日韩av电影网 | 精品亚洲永久免费精品 | 黄色成人在线 | 成年人在线视频 | 四虎视频 | 中文字幕色| 天天干天天谢 | 欧美日韩在线视频一区 | 日本激情视频一区二区三区 | 五月天婷婷在线视频 | 色综合一区二区三区 | 亚洲精品国产第一综合99久久 | 亚洲国产中文字幕 | 国产精品久久久久久久久久 | 99这里只有精品视频 | 天天干天天av | 欧美一区二区大片 |