python自定義異常和主動拋出異常
自定義異常主要是利用了自己定義的異常類的名字,對異常進行分門別類,再沒有別的作用
import re import os class ExistsError(Exception): pass class KeyInvalidError(Exception): pass def fun(path,mnk): """ 去path路徑的文件中,找到前綴為prev的一行數據,獲取數據並返回給調用者。 1000,成功 1001,文件不存在 1002,關鍵字為空 1003,未知錯誤 ... :return: """ response = {'code': 1000, 'data': None} try: with open(path,encoding="utf-8") as f1: line=f1.readline() str = re.match("mnk", line) if not os.path.exists(path): raise Exception() #拋出的是ExistsError類的一個實例 if not str: raise KeyInvalidError() except ExistsError as e: #下面的捕獲異常是逐行往下匹配的,只要捕獲到異常就不往下執行了 response['code']=1003 #捕獲異常以后可以做一些自己定義的東西 print(response['code']) except Exception as e: #**自己定義多個異常類名的目的就是將來區分不同的錯誤類型,再沒有別的意思 response['code'] = 1004 print(response['code']) fun(r"E:\day26\s15day26\test", "p")
下面是對主動拋出異常的一點總結
#知識點:如何自定義類 class MyException(Exception): #讓MyException類繼承Exception def __init__(self,name,age): self.name = name self.age = age try: #知識點:主動拋出異常,就是實例化一個異常類 raise MyException("zhansgan",19) #實例化一個異常,實例化的時候需要傳參數 except MyException as obj: #這里體現一個封裝, print(obj.age,obj.name) #捕獲的就是MyException類攜帶過來的信息 except Exception as obj: #萬能捕獲,之前的可能捕獲不到,這里添加Exception作為保底 print(obj)