raise from
try: try: 1 / 0 except ZeroDivisionError as e: raise Exception("with_traceback") from e except Exception as e: print(e, e.__cause__, type(e.__cause__)) try: 1 / 0 except ZeroDivisionError as e: raise Exception("with_traceback") from e
The bottom exception only has the stacktrace from where we raised our exception. Notice the bottom exception only has the stacktrace where we raised our exception. Your caller could still get the original exception by accessing the __cause__ attribute of the exception they catch.
with_traceback
try: try: 1 / 0 except ZeroDivisionError as e: raise Exception("with_traceback").with_traceback(e.__traceback__) except Exception as e: print(e, e.__cause__, type(e.__cause__)) try: 1 / 0 except ZeroDivisionError as e: raise Exception("with_traceback").with_traceback(e.__traceback__)
Using this form, the exception your caller would catch has the trackback from where the original error occurred. Notice the bottom exception has the line where we performed the invalid division as well as the line where we reraise the exception.
Custom Exception
class CloudFirewallError(Exception): def __init__(self, message: str): super().__init__(f'CloudFirewallError: {message}') class ApiError(Exception): def __init__(self, status_code): if status_code == 403: message = 'Rate limit reached. Please wait a minute and try again' else: message = f'HTTP status code: {status_code}' super().__init__(message)
标签:__,Exception,.__,Python,traceback,exception,try From: https://www.cnblogs.com/dissipate/p/17265645.html