python自定義異常和主動拋出異常


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)

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM