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)
