5. 내장 예외¶
파이썬에서, 모든 예외는 BaseException
에서 파생된 클래스의 인스턴스여야 합니다. 특정 클래스를 언급하는 except
절을 갖는 try
문에서, 그 절은 그 클래스에서 파생된 모든 예외 클래스를 처리합니다 (하지만 그것 이 계승하는 예외 클래스는 처리하지 않습니다). 서브 클래싱을 통해 관련되지 않은 두 개의 예외 클래스는 같은 이름을 갖는다 할지라도 결코 등등하게 취급되지 않습니다.
아래 나열된 내장 예외는 인터프리터나 내장 함수에 의해 생성될 수 있습니다. 따로 언급된 경우를 제외하고는, 에러의 자세한 원인을 나타내는 《연관된 값》을 갖습니다. 이것은 여러 항목의 정보 (예, 에러 코드와 그 코드를 설명하는 문자열)를 담은 문자열이나 튜플 일 수 있습니다. 연관된 값은 보통 예외 클래스의 생성자에 인자로 전달됩니다.
사용자 코드는 내장 예외를 일으킬 수 있습니다. 이것은 예외 처리기를 검사하거나 인터프리터가 같은 예외를 발생시키는 상황과 《같은》 에러 조건을 보고하는 데 사용할 수 있습니다. 그러나 사용자 코드가 부적절한 에러를 발생시키는 것을 막을 방법이 없음을 유의하십시오.
내장 예외 클래스는 새 예외를 정의하기 위해 서브 클래싱 될 수 있습니다. BaseException
이 아니라 Exception
클래스 나 그 서브 클래스 중 하나에서 새로운 예외를 파생시킬 것을 권장합니다. 예외 정의에 대한 더 많은 정보는 파이썬 자습서의 사용자 정의 예외 에 있습니다.
except
또는 finally
절에서 예외를 일으킬 때 (또는 다시 일으킬 때), __context__
는 자동으로 마지막으로 잡힌 예외로 설정됩니다; 이 새 예외가 처리되지 않으면, 결국 표시되는 트레이스백은 원래 예외와 최종 예외를 포함합니다.
(현재 처리 중인 예외를 다시 발생시키기 위해 raise
만 사용하는 대신) 새 예외를 일으킬 때, 묵시적인 예외 컨텍스트는 암시적인 예외 상황은 명시적 원인으로 보충될 수 있는데, raise
와 from
을 사용합니다:
raise new_exc from original_exc
from
다음의 표현식은 예외이거나 None
이어야 합니다. 이 표현식을 새로 일으키는 예외의 __cause__
로 설정합니다. __cause__
를 설정하면, 묵시적으로 __suppress_context__
를 True
로 설정합니다. 그래서, raise new_exc from None
을 사용하면 표시의 목적상 이전 예외를 새로운 것으로 대체 하는 효과를 주면서 (예를 들어 KeyError
를 AttributeError
로), 디버깅할 때 검사할 수 있도록 이전의 예외를 __context__
에 남겨둡니다.
기본 트레이스백 표시 코드는 예외 자체의 트레이스백 뿐만 아니라 이러한 연결된 예외를 보여줍니다. __cause__
에 명시적으로 연결된 예외는 있으면 항상 표시됩니다. __context__
에 묵시적으로 연결된 예외는 __cause__
가 None
이고 __suppress_context__
가 거짓인 경우에만 표시됩니다.
두 경우 모두, 예외 자신은 항상 연결된 예외 뒤에 표시되어서, 트레이스백의 마지막 줄은 항상 마지막에 발생한 예외를 보여줍니다.
5.1. 베이스 클래스¶
다음 예외는 주로 다른 예외의 베이스 클래스로 사용됩니다.
-
exception
BaseException
¶ 모든 내장 예외의 베이스 클래스입니다. 사용자 정의 클래스에 의해 직접 상속되는 것이 아닙니다 (그런 목적으로는
Exception
을 사용하세요). 이 클래스의 인스턴스에 대해str()
이 호출되면, 인스턴스로 전달된 인자(들)의 표현을 돌려줍니다. 인자가 없는 경우는 빈 문자열을 돌려줍니다.-
args
¶ 예외 생성자에 주어진 인자들의 튜플. 일부 내장 예외(예,
OSError
)는 특정 수의 인자를 기대하고 이 튜플의 요소에 특별한 의미를 할당하는 반면, 다른 것들은 보통 오류 메시지를 제공하는 단일 문자열로만 호출됩니다.
-
with_traceback
(tb)¶ 이 메서드는 tb 를 예외의 새 트레이스백으로 설정하고 예외 객체를 돌려줍니다. 일반적으로 다음과 같은 예외 처리 코드에서 사용됩니다:
try: ... except SomeException: tb = sys.exc_info()[2] raise OtherException(...).with_traceback(tb)
-
-
exception
Exception
¶ 모든 시스템 종료 외의 내장 예외는 이 클래스 파생됩니다. 모든 사용자 정의 예외도 이 클래스에서 파생되어야 합니다.
-
exception
ArithmeticError
¶ 다양한 산술 에러가 일으키는 내장 예외들의 베이스 클래스:
OverflowError
,ZeroDivisionError
,FloatingPointError
.
-
exception
LookupError
¶ 매핑 또는 시퀀스에 사용된 키 나 인덱스가 잘못되었을 때 발생하는 예외의 베이스 클래스:
IndexError
,KeyError
.codecs.lookup()
은 이 예외를 직접 일으킬 수 있습니다.
5.2. 구체적인 예외¶
다음 예외는 일반적으로 직접 일으키는데 사용하는 예외입니다.
-
exception
AttributeError
¶ 어트리뷰트 참조(어트리뷰트 참조를 보세요)나 대입이 실패할 때 발생합니다. (객체가 어트리뷰트 참조나 어트리뷰트 대입을 아예 지원하지 않으면
TypeError
가 발생합니다.)
-
exception
EOFError
¶ input()
함수가 데이터를 읽지 못한 상태에서 EOF (end-of-file) 조건을 만날 때 발생합니다. (주의하세요:io.IOBase.read()
와io.IOBase.readline()
메서드는 EOF를 만날 때 빈 문자열을 돌려줍니다.)
-
exception
FloatingPointError
¶ 부동 소수점 연산이 실패할 때 발생합니다. 이 예외는 항상 정의되어 있지만, 파이썬이
--with-fpectl
옵션으로 설정되었거나,WANT_SIGFPE_HANDLER
심볼이pyconfig.h
파일에 정의되어있을 때만 발생합니다.
-
exception
GeneratorExit
¶ 제너레이터 또는 코루틴 이 닫힐 때 발생합니다;
generator.close()
와coroutine.close()
를 보십시오. 기술적으로 에러가 아니므로Exception
대신에BaseException
을 직접 계승합니다.
-
exception
ImportError
¶ Raised when an
import
statement fails to find the module definition or when afrom ... import
fails to find a name that is to be imported.name
과path
어트리뷰트는 생성자에 키워드 전용 인자를 사용하여 설정할 수 있습니다. 설정된 경우, 각각 임포트하려고 시도한 모듈의 이름과 예외를 유발한 파일의 경로를 나타냅니다.버전 3.3으로 변경:
name
과path
어트리뷰트를 추가했습니다.
-
exception
IndexError
¶ 시퀀스 인덱스가 범위를 벗어날 때 발생합니다. (슬라이스 인덱스는 허용된 범위 내에 들어가도록 자동으로 잘립니다; 인덱스가 정수가 아니면
TypeError
가 발생합니다.)
-
exception
KeyError
¶ 매핑 (딕셔너리) 키가 기존 키 집합에서 발견되지 않을 때 발생합니다.
-
exception
KeyboardInterrupt
¶ 사용자가 인터럽트 키(일반적으로 Control-C 또는 Delete)를 누를 때 발생합니다. 실행 중에 인터럽트 검사가 정기적으로 수행됩니다.
Exception
을 잡는 코드에 의해 우연히 잡혀서, 인터프리터가 종료하는 것을 막지 못하도록BaseException
를 계승합니다.
-
exception
MemoryError
¶ 작업에 메모리가 부족하지만, 상황이 여전히 (일부 객체를 삭제해서) 복구될 수 있는 경우 발생합니다. 연관된 값은 어떤 종류의 (내부) 연산이 메모리를 다 써 버렸는지를 나타내는 문자열입니다. 하부 메모리 관리 아키텍처(C의
malloc()
함수)때문에, 인터프리터가 항상 이 상황을 완벽하게 복구할 수 있는 것은 아닙니다; 그런데도 통제를 벗어난 프로그램이 원인인 경우를 위해, 스택 트레이스백을 인쇄할 수 있도록 예외를 일으킵니다.
-
exception
NameError
¶ 지역 또는 전역 이름을 찾을 수 없을 때 발생합니다. 이는 정규화되지 않은 이름에만 적용됩니다. 연관된 값은 찾을 수 없는 이름을 포함하는 에러 메시지입니다.
-
exception
NotImplementedError
¶ This exception is derived from
RuntimeError
. In user defined base classes, abstract methods should raise this exception when they require derived classes to override the method.
-
exception
OSError
([arg])¶ -
exception
OSError
(errno, strerror[, filename[, winerror[, filename2]]]) 이 예외는 시스템 함수가 시스템 관련 에러를 돌려줄 때 발생하는데, 《파일을 찾을 수 없습니다(file not found)》 나 《디스크가 꽉 찼습니다(disk full)》 와 같은 (잘못된 인자형이나 다른 부수적인 에러가 아닌) 입출력 실패를 포함합니다.
생성자의 두 번째 형식은 아래에 설명된 해당 어트리뷰트를 설정합니다. 어트리뷰트를 지정하지 않으면 기본적으로
None
이 됩니다. 이전 버전과의 호환성을 위해, 세 개의 인자가 전달되면,args
어트리뷰트는 처음 두 생성자 인자의 2-튜플만 포함합니다.아래의 OS exceptions 에서 설명하는 것처럼, 생성자는 종종
OSError
의 서브 클래스를 돌려줍니다. 구체적인 서브 클래스는 최종errno
값에 따라 다릅니다. 이 동작은OSError
를 직접 혹은 별칭을 통해 생성할 때만 일어나고, 서브클래싱할 때는 상속되지 않습니다.-
errno
¶ C 변수
errno
로부터 온 숫자 에러 코드.
-
winerror
¶ 윈도우에서, 네이티브 윈도우 에러 코드를 제공합니다.
errno
어트리뷰트는 이 네이티브 에러 코드를 POSIX 코드로 대략 변환한 것입니다.윈도우에서, winerror 생성자 인자가 정수인 경우,
errno
어트리뷰트는 윈도우 에러 코드에서 결정되며 errno 인자는 무시됩니다. 다른 플랫폼에서는 winerror 인자가 무시되고winerror
어트리뷰트가 없습니다.
-
strerror
¶ 운영 체제에서 제공하는 해당 에러 메시지. POSIX에서는 C 함수
perror()
로, 윈도우에서는FormatMessage()
로 포맷합니다.
-
filename
¶ -
filename2
¶ (
open()
또는os.unlink()
와 같은) 파일 시스템 경로와 관련된 예외의 경우,filename
은 함수에 전달 된 파일 이름입니다. (os.rename()
처럼) 두 개의 파일 시스템 경로를 수반하는 함수의 경우,filename2
는 두 번째 파일 이름에 해당합니다.
버전 3.3으로 변경:
EnvironmentError
,IOError
,WindowsError
,socket.error
,select.error
,mmap.error
가OSError
로 병합되었고, 생성자는 서브 클래스를 반환할 수 있습니다.버전 3.4으로 변경:
filename
속성은 이제 파일 시스템 인코딩으로 인코딩되거나 디코딩된 이름 대신 함수에 전달 된 원래 파일 이름입니다. 또한 filename2 생성자 인자 및 어트리뷰트가 추가되었습니다.-
-
exception
OverflowError
¶ 산술 연산의 결과가 너무 커서 표현할 수 없을 때 발생합니다. 정수에서는 발생하지 않습니다 (포기하기보다는
MemoryError
를 일으키게 될 겁니다). 그러나, 역사적인 이유로, 때로 OverflowError는 요구되는 범위를 벗어난 정수의 경우도 발생합니다. C에서 부동 소수점 예외 처리의 표준화가 부족하므로, 대부분의 부동 소수점 연산은 검사되지 않습니다.
-
exception
RecursionError
¶ 이 예외는
RuntimeError
에서 파생됩니다. 인터프리터가 최대 재귀 깊이(sys.getrecursionlimit()
참조)가 초과하였음을 감지할 때 발생합니다.버전 3.5에 추가: 이전에는 평범한
RuntimeError
가 발생했습니다.
-
exception
ReferenceError
¶ 이 예외는
weakref.proxy()
함수가 만든 약한 참조 프락시가 이미 가비지 수집된 참조 대상의 어트리뷰트를 액세스하는 데 사용될 때 발생합니다. 약한 참조에 대한 더 자세한 정보는weakref
모듈을 보십시오.
-
exception
RuntimeError
¶ 다른 범주에 속하지 않는 에러가 감지될 때 발생합니다. 연관된 값은 정확히 무엇이 잘못되었는지를 나타내는 문자열입니다.
-
exception
StopIteration
¶ 이터레이터에 의해 생성된 항목이 더 없다는 것을 알려주기 위해, 내장 함수
next()
와 이터레이터의__next__()
메서드가 일으킵니다.예외 객체는
value
라는 하나의 어트리뷰트를 가지고 있습니다. 이 어트리뷰트는 예외를 생성할 때 인자로 주어지며, 기본값은None
입니다.제너레이터 나 코루틴 함수가 복귀할 때, 새
StopIteration
인스턴스를 발생시키고, 함수가 돌려주는 값을 예외 생성자의value
파라미터로 사용합니다.from __future__ import generator_stop
지시어가 있는 상태에서 정의된 제너레이터 함수가StopIteration
를 일으키면,RuntimeError
로 변환됩니다 (StopIteration
은 새 예외의 원인(__cause__
)으로 남겨둡니다).버전 3.3으로 변경:
value
어트리뷰트와 제너레이터 함수가 이 값을 돌려주는 기능을 추가했습니다.버전 3.5으로 변경: RuntimeError 변환을 도입했습니다.
-
exception
StopAsyncIteration
¶ 반드시 비동기 이터레이터 객체의
__anext__()
메서드가 이터레이션을 멈추고자 할 때 발생시켜야 합니다.버전 3.5에 추가.
-
exception
SyntaxError
¶ 파서가 문법 오류를 만날 때 발생합니다.
import
문에서, 내장 함수exec()
나eval()
호출에서, 초기 스크립트나 (대화형으로) 표준 입력을 읽을 때 발생할 수 있습니다.세부 사항을 쉽게 확인할 수 있도록, 이 클래스의 인스턴스에는
filename
,lineno
,offset
및text
어트리뷰트가 있습니다. 예외 인스턴스의str()
은 메시지만 돌려줍니다.
-
exception
IndentationError
¶ 잘못된 들여쓰기와 관련된 문법 오류의 베이스 클래스입니다.
SyntaxError
의 서브 클래스입니다.
-
exception
TabError
¶ 들여쓰기가 일관성없는 탭과 스페이스 사용을 포함하는 경우 발생합니다.
IndentationError
의 서브 클래스입니다.
-
exception
SystemError
¶ 인터프리터가 내부 에러를 발견했지만, 모든 희망을 포기할 만큼 상황이 심각해 보이지는 않을 때 발생합니다. 연관된 값은 무엇이 잘못되었는지 (저수준의 용어로) 나타내는 문자열입니다.
이것을 파이썬 인터프리터의 저자 또는 관리자에게 알려야 합니다. 파이썬 인터프리터의 버전 (
sys.version
; 대화식 파이썬 세션의 시작 부분에도 출력됩니다), 정확한 에러 메시지 (예외의 연관된 값) 그리고 가능하다면 에러를 일으킨 프로그램의 소스를 제공해 주십시오.
-
exception
SystemExit
¶ 이 예외는
sys.exit()
함수가 일으킵니다.Exception
을 잡는 코드에 의해 우연히 잡히지 않도록,Exception
대신에BaseException
을 상속합니다. 이렇게 하면 예외가 올바르게 전파되어 인터프리터가 종료됩니다. 처리되지 않으면, 파이썬 인터프리터가 종료됩니다; 스택 트레이스백은 인쇄되지 않습니다. 생성자는sys.exit()
에 전달된 것과 같은 선택적 인자를 받아들입니다. 값이 정수이면 시스템 종료 상태를 지정합니다 (C의exit()
함수에 전달됩니다);None
이면 종료 상태는 0입니다; 다른 형(가령 문자열)이면 객체의 값이 인쇄되고 종료 상태는 1입니다.sys.exit()
에 대한 호출은 예외로 변환되어 뒷정리 처리기 (try
문의finally
절) 가 실행될 수 있도록 합니다. 그래서 디버거는 제어권을 잃을 위험 없이 스크립트를 실행할 수 있습니다. 즉시 종료가 절대적으로 필요한 경우에는os._exit()
함수를 사용할 수 있습니다 (예를 들어,os.fork()
호출 후의 자식 프로세스에서).-
code
¶ 생성자에 전달되는 종료 상태 또는 에러 메시지입니다. (기본값은
None
입니다.)
-
-
exception
TypeError
¶ 연산이나 함수가 부적절한 형의 객체에 적용될 때 발생합니다. 연관된 값은 형 불일치에 대한 세부 정보를 제공하는 문자열입니다.
-
exception
UnboundLocalError
¶ 함수 나 메서드에서 지역 변수를 참조하지만, 해당 변수에 값이 연결되지 않으면 발생합니다. 이것은
NameError
의 서브 클래스입니다.
-
exception
UnicodeError
¶ 유니코드 관련 인코딩 또는 디코딩 에러가 일어날 때 발생합니다.
ValueError
의 서브 클래스입니다.UnicodeError
는 인코딩이나 디코딩 에러를 설명하는 어트리뷰트를 가지고 있습니다. 예를 들어,err.object[err.start:err.end]
는 코덱이 실패한 잘못된 입력을 제공합니다.-
encoding
¶ 에러를 발생시킨 인코딩의 이름입니다.
-
reason
¶ 구체적인 코덱 오류를 설명하는 문자열입니다.
-
object
¶ 코덱이 인코딩 또는 디코딩하려고 시도한 객체입니다.
-
-
exception
UnicodeEncodeError
¶ 인코딩 중에 유니코드 관련 에러가 일어나면 발생합니다.
UnicodeError
의 서브 클래스입니다.
-
exception
UnicodeDecodeError
¶ 디코딩 중에 유니코드 관련 에러가 일어나면 발생합니다.
UnicodeError
의 서브 클래스입니다.
-
exception
UnicodeTranslateError
¶ 번역 중에 유니코드 관련 에러가 일어나면 발생합니다.
UnicodeError
의 서브 클래스입니다.
-
exception
ValueError
¶ 내장 연산이나 함수가 올바른 형이지만 부적절한 값을 가진 인자를 받았고, 상황이
IndexError
처럼 더 구체적인 예외로 설명되지 않는 경우 발생합니다.
-
exception
ZeroDivisionError
¶ 나누기 또는 모듈로 연산의 두 번째 인자가 0일 때 발생합니다. 연관된 값은 피연산자의 형과 연산을 나타내는 문자열입니다.
다음 예외는 이전 버전과의 호환성을 위해 유지됩니다; 파이썬 3.3부터는 OSError
의 별칭입니다.
-
exception
EnvironmentError
¶
-
exception
IOError
¶
-
exception
WindowsError
¶ 윈도우에서만 사용할 수 있습니다.
5.2.1. OS 예외¶
다음의 예외는 OSError
의 서브 클래스이며, 시스템 에러 코드에 따라 발생합니다.
-
exception
BlockingIOError
¶ 비 블록 동작으로 설정된 객체(가령 소켓)에 블록이 필요한 연산이 수행되면 발생합니다.
errno
EAGAIN
,EALREADY
,EWOULDBLOCK
,EINPROGRESS
에 해당합니다.OSError
의 것 외에도,BlockingIOError
는 어트리뷰트를 하나 더 가질 수 있습니다:
-
exception
ChildProcessError
¶ 자식 프로세스에 대한 작업이 실패할 때 발생합니다.
errno
ECHILD
에 해당합니다.
-
exception
ConnectionError
¶ 연결 관련 문제에 대한 베이스 클래스입니다.
서브 클래스는
BrokenPipeError
,ConnectionAbortedError
,ConnectionRefusedError
및ConnectionResetError
입니다.
-
exception
BrokenPipeError
¶ ConnectionError
의 서브 클래스로서, 다른 쪽 끝이 닫힌 파이프에 쓰려고 하거나, 쓰기가 종료된 소켓에 쓰려고 할 때 발생합니다.errno
EPIPE
와ESHUTDOWN
에 해당합니다.
-
exception
ConnectionAbortedError
¶ ConnectionError
의 서브 클래스로서, 연결 시도가 상대방에 의해 중단(abort)될 때 발생합니다.errno
ECONNABORTED
에 해당합니다.
-
exception
ConnectionRefusedError
¶ ConnectionError
의 서브 클래스로서, 연결 시도가 상대방에 의해 거부(refuse)될 때 발생합니다.errno
ECONNREFUSED
에 해당합니다.
-
exception
ConnectionResetError
¶ ConnectionError
의 서브 클래스로서, 연결이 상대방에 의해 강제 종료(reset)될 때 발생합니다.errno
ECONNRESET
에 해당합니다.
-
exception
FileExistsError
¶ 이미 존재하는 파일이나 디렉터리를 만들려고 할 때 발생합니다.
errno
EEXIST
에 해당합니다.
-
exception
FileNotFoundError
¶ 파일이나 디렉터리가 요청되었지만 존재하지 않을 때 발생합니다.
errno
ENOENT
에 해당합니다.
-
exception
InterruptedError
¶ 시스템 호출이 들어오는 시그널에 의해 중단될 때 발생합니다.
errno
EINTR
에 해당합니다.버전 3.5으로 변경: 이제 파이썬은 시스템 호출이 시그널에 의해 중단될 때, 시그널 처리기가 예외를 일으키는 경우를 제외하고 (이유는 PEP 475 를 참조하세요),
InterruptedError
를 일으키는 대신 시스템 호출을 재시도합니다.
-
exception
IsADirectoryError
¶ 디렉터리에 파일 연산(가령
os.remove()
)이 요청되었을 때 발생합니다.errno
EISDIR
에 해당합니다.
-
exception
NotADirectoryError
¶ 디렉터리가 아닌 것에 디렉터리 연산(가령
os.listdir()
)이 요청되었을 때 발생합니다.errno
ENOTDIR
에 해당합니다.
-
exception
PermissionError
¶ 적절한 접근권 (가령 파일 시스템 권한) 없이 연산을 실행하려고 할 때 발생합니다.
errno
EACCES
와EPERM
에 해당합니다.
-
exception
ProcessLookupError
¶ 주어진 프로세스가 존재하지 않을 때 발생합니다.
errno
ESRCH
에 해당합니다.
-
exception
TimeoutError
¶ 시스템 함수가 시스템 수준에서 시간 초과 될 때 발생합니다.
errno
ETIMEDOUT
에 해당합니다.
버전 3.3에 추가: 위의 모든 OSError
서브 클래스가 추가되었습니다.
더 보기
PEP 3151 - OS 및 IO 예외 계층 구조 재작업
5.3. 경고¶
다음 예외는 경고 범주로 사용됩니다; 자세한 정보는 warnings
모듈을 보십시오.
-
exception
Warning
¶ 경고 범주의 베이스 클래스입니다.
-
exception
UserWarning
¶ 사용자 코드에 의해 만들어지는 경고의 베이스 클래스입니다.
-
exception
DeprecationWarning
¶ 폐지된 기능에 대한 경고의 베이스 클래스입니다.
-
exception
PendingDeprecationWarning
¶ 장래에 폐지될 기능에 관한 경고의 베이스 클래스입니다.
-
exception
SyntaxWarning
¶ 모호한 문법에 대한 경고의 베이스 클래스입니다.
-
exception
RuntimeWarning
¶ 모호한 실행 시간 동작에 대한 경고의 베이스 클래스입니다.
-
exception
FutureWarning
¶ 장래에 의미상으로 변경되는 구조물에 관한 경고의 베이스 클래스입니다.
-
exception
ImportWarning
¶ 모듈 임포트에 있을 수 있는 실수에 대한 경고의 베이스 클래스입니다.
-
exception
UnicodeWarning
¶ 유니코드와 관련된 경고의 베이스 클래스입니다.
-
exception
ResourceWarning
¶ 자원 사용과 관련된 경고의 베이스 클래스입니다.
버전 3.2에 추가.
5.4. 예외 계층 구조¶
내장 예외의 클래스 계층 구조는 다음과 같습니다:
BaseException
+-- SystemExit
+-- KeyboardInterrupt
+-- GeneratorExit
+-- Exception
+-- StopIteration
+-- StopAsyncIteration
+-- ArithmeticError
| +-- FloatingPointError
| +-- OverflowError
| +-- ZeroDivisionError
+-- AssertionError
+-- AttributeError
+-- BufferError
+-- EOFError
+-- ImportError
+-- LookupError
| +-- IndexError
| +-- KeyError
+-- MemoryError
+-- NameError
| +-- UnboundLocalError
+-- OSError
| +-- BlockingIOError
| +-- ChildProcessError
| +-- ConnectionError
| | +-- BrokenPipeError
| | +-- ConnectionAbortedError
| | +-- ConnectionRefusedError
| | +-- ConnectionResetError
| +-- FileExistsError
| +-- FileNotFoundError
| +-- InterruptedError
| +-- IsADirectoryError
| +-- NotADirectoryError
| +-- PermissionError
| +-- ProcessLookupError
| +-- TimeoutError
+-- ReferenceError
+-- RuntimeError
| +-- NotImplementedError
| +-- RecursionError
+-- SyntaxError
| +-- IndentationError
| +-- TabError
+-- SystemError
+-- TypeError
+-- ValueError
| +-- UnicodeError
| +-- UnicodeDecodeError
| +-- UnicodeEncodeError
| +-- UnicodeTranslateError
+-- Warning
+-- DeprecationWarning
+-- PendingDeprecationWarning
+-- RuntimeWarning
+-- SyntaxWarning
+-- UserWarning
+-- FutureWarning
+-- ImportWarning
+-- UnicodeWarning
+-- BytesWarning
+-- ResourceWarning