Python

예외 처리

이 장에서 설명하는 함수를 사용하면 파이썬 예외를 처리하고 발생시킬 수 있습니다. 파이썬 예외 처리의 기본 사항을 이해하는 것이 중요합니다. POSIX errno 변수와 비슷하게 작동합니다: 발생한 마지막 에러에 대한 전역 표시기(스레드 당)가 있습니다. 대부분 C API 함수는 성공 시 이를 지우지 않지만, 실패 시 에러의 원인을 나타내도록 설정합니다. 대부분 C API 함수는 에러 표시기도 반환합니다, 일반적으로 포인터를 반환해야 하면 NULL, 정수를 반환하면 -1을 반환합니다 (예외: PyArg_* 함수는 성공하면 1을, 실패하면 0을 반환합니다).

구체적으로, 에러 표시기는 세 가지 객체 포인터로 구성됩니다: 예외 형, 예외 값 및 트레이스백 객체. 이러한 포인터들은 설정되지 않으면 NULL이 될 수 있습니다 (하지만 일부 조합은 금지되어 있습니다, 예를 들어 예외 형이 NULL이면 NULL이 아닌 트레이스백을 가질 수 없습니다).

호출한 일부 함수가 실패하여 함수가 실패해야 할 때, 일반적으로 에러 표시기를 설정하지 않습니다; 호출된 함수가 이미 설정했습니다. 에러를 처리하고 예외를 지우거나 보유한 모든 리소스(가령 객체 참조나 메모리 할당)를 정리한 후 반환해야 할 책임이 있습니다; 에러를 처리할 준비가 되지 않았을 때 정상적으로 계속되지 않아야 합니다. 에러로 인해 반환하면, 호출자에게 에러가 설정되었음을 알리는 것이 중요합니다. 에러를 처리하지 않거나 신중하게 전파하지 않으면, 파이썬/C API에 대한 추가 호출이 의도한 대로 작동하지 않을 수 있으며 알 수 없는 방식으로 실패할 수 있습니다.

참고

에러 표시기는 sys.exc_info()의 결과가 아닙니다. 전자는 아직 포착되지 않은 (따라서 여전히 전파 중인) 예외에 해당하는 반면, 후자는 포착된 후 (따라서 전파가 중단된) 예외를 반환합니다.

인쇄와 지우기

void PyErr_Clear()
…의 일부 안정 ABI.

에러 표시기를 지웁니다. 에러 표시기가 설정되어 있지 않으면 효과가 없습니다.

void PyErr_PrintEx(int set_sys_last_vars)
…의 일부 안정 ABI.

표준 트레이스백을 sys.stderr로 인쇄하고 에러 표시기를 지웁니다. 에러가 SystemExit아닌 한, 이 경우에는 트레이스백이 인쇄되지 않고 파이썬 프로세스는 SystemExit 인스턴스에 의해 지정된 에러 코드로 종료됩니다.

에러 표시기가 설정된 경우**에만** 이 함수를 호출하십시오. 그렇지 않으면 치명적인 에러가 발생합니다!

set_sys_last_vars가 0이 아니면, 변수 sys.last_exc 는 인쇄되는 예외로 설정됩니다. 하위 호환성을 위해, 폐지된 변수 sys.last_type, sys.last_valuesys.last_traceback 도 각각 이 예외의 형, 값 및 트레이스백으로 설정됩니다.

버전 3.12에서 변경: sys.last_exc 설정이 추가되었습니다.

void PyErr_Print()
…의 일부 안정 ABI.

PyErr_PrintEx(1)의 별칭.

void PyErr_WriteUnraisable(PyObject *obj)
…의 일부 안정 ABI.

현재 예외와 obj 인자를 사용하여 sys.unraisablehook() 을 호출합니다.

이 유틸리티 함수는 예외가 설정되었지만, 인터프리터가 실제로 예외를 발생시킬 수 없을 때 sys.stderr에 경고 메시지를 인쇄합니다. 예를 들어, __del__() 메서드에서 예외가 발생할 때 사용됩니다.

이 함수는 발생시킬 수 없는 예외가 발생한 문맥을 식별하는 단일 인자 obj로 호출됩니다. 가능하면, obj의 repr이 경고 메시지에 인쇄됩니다. objNULL이면, 트래이스백만 인쇄됩니다.

이 함수를 호출할 때 예외를 설정되어 있어야 합니다.

버전 3.4에서 변경: 추적(traceback)을 출력합니다. objNULL 인 경우에만 추적을 출력합니다.

버전 3.8에서 변경: sys.unraisablehook() 을 사용합니다.

void PyErr_FormatUnraisable(const char *format, ...)

PyErr_WriteUnraisable() 와 유사하지만, format 및 후속 매개변수가 경고 메시지를 포맷하는 데 사용됩니다. 이들은 PyUnicode_FromFormat() 에서와 동일한 의미와 값을 가집니다. PyErr_WriteUnraisable(obj) 은 대략적으로 PyErr_FormatUnraisable("Exception ignored in: %R", obj) 와 동일합니다. formatNULL 인 경우, 트레이스백만 출력됩니다.

Added in version 3.13.

void PyErr_DisplayException(PyObject *exc)
…의 일부 안정 ABI 버전 3.12 이후로.

체인된 예외와 노트를 포함하여 exc 의 표준 트레이스백 표시를 sys.stderr 에 출력합니다.

Added in version 3.12.

예외 발생시키기

이 함수들은 현재 스레드의 에러 표시기를 설정하는 데 도움이 됩니다. 편의를 위해, 이러한 함수 중 일부는 항상 return 문에서 사용할 NULL 포인터를 반환합니다.

void PyErr_SetString(PyObject *type, const char *message)
…의 일부 안정 ABI.

이것은 에러 표시기를 설정하는 가장 일반적인 방법입니다. 첫 번째 인자는 예외 형을 지정합니다; 일반적으로 표준 예외 중 하나입니다, 예를 들어 PyExc_RuntimeError. 새로운 강한 참조를 만들 필요가 없습니다 (예를 들어, Py_INCREF()로). 두 번째 인자는 에러 메시지입니다; 'utf-8' 에서 디코딩됩니다.

void PyErr_SetObject(PyObject *type, PyObject *value)
…의 일부 안정 ABI.

이 함수는 PyErr_SetString()과 유사하지만, 예외의 “값”에 대해 임의의 파이썬 객체를 지정할 수 있습니다.

PyObject *PyErr_Format(PyObject *exception, const char *format, ...)
반환값: 항상 NULL. …의 일부 안정 ABI.

이 함수는 에러 표시기를 설정하고 NULL을 반환합니다. exception은 파이썬 예외 클래스여야 합니다. format과 후속 매개 변수는 에러 메시지를 포맷하는 데 도움이 됩니다; PyUnicode_FromFormat()에서와 같은 의미와 값을 갖습니다. format은 ASCII 인코딩된 문자열입니다.

PyObject *PyErr_FormatV(PyObject *exception, const char *format, va_list vargs)
반환값: 항상 NULL. …의 일부 안정 ABI 버전 3.5 이후로.

PyErr_Format()과 같지만, 가변 개수의 인자 대신 va_list 인자를 취합니다.

Added in version 3.5.

void PyErr_SetNone(PyObject *type)
…의 일부 안정 ABI.

이것은 PyErr_SetObject(type, Py_None)의 줄임 표현입니다.

int PyErr_BadArgument()
…의 일부 안정 ABI.

이것은 PyErr_SetString(PyExc_TypeError, message)의 줄임 표현입니다, 여기서 message는 잘못된 인자로 내장 연산이 호출되었음을 나타냅니다. 대부분 내부 용입니다.

PyObject *PyErr_NoMemory()
반환값: 항상 NULL. …의 일부 안정 ABI.

이것은 PyErr_SetNone(PyExc_MemoryError)의 줄임 표현입니다; NULL을 반환해서 객체 할당 함수는 메모리가 부족할 때 return PyErr_NoMemory(); 라고 쓸 수 있습니다.

PyObject *PyErr_SetFromErrno(PyObject *type)
반환값: 항상 NULL. …의 일부 안정 ABI.

C 라이브러리 함수가 에러를 반환하고 C 변수 errno를 설정했을 때 예외를 발생시키는 편의 함수입니다. 첫 번째 항목이 정수 errno 값이고 두 번째 항목이 (strerror()에서 얻은) 해당 에러 메시지인 튜플 객체를 만든 다음, PyErr_SetObject(type, object)를 호출합니다. 유닉스에서, errno 값이 시스템 호출이 중단되었음을 나타내는 EINTR이면, PyErr_CheckSignals()를 호출하고 이것이 에러 표시기를 설정하면, 설정된 그대로 둡니다. 이 함수는 항상 NULL을 반환해서, 시스템 호출에 대한 래퍼 함수는 시스템 호출이 에러를 반환할 때 return PyErr_SetFromErrno(type); 이라고 쓸 수 있습니다.

PyObject *PyErr_SetFromErrnoWithFilenameObject(PyObject *type, PyObject *filenameObject)
반환값: 항상 NULL. …의 일부 안정 ABI.

PyErr_SetFromErrno()와 유사하지만, filenameObjectNULL이 아니면, type의 생성자에 세 번째 매개 변수로 전달된다는 추가 동작이 있습니다. OSError 예외의 경우, 예외 인스턴스의 filename 어트리뷰트를 정의하는 데 사용됩니다.

PyObject *PyErr_SetFromErrnoWithFilenameObjects(PyObject *type, PyObject *filenameObject, PyObject *filenameObject2)
반환값: 항상 NULL. …의 일부 안정 ABI 버전 3.7 이후로.

PyErr_SetFromErrnoWithFilenameObject()와 유사하지만, 두 개의 파일명을 취하는 함수가 실패할 때 에러를 발생시키기 위해 두 번째 파일명 객체를 취합니다.

Added in version 3.4.

PyObject *PyErr_SetFromErrnoWithFilename(PyObject *type, const char *filename)
반환값: 항상 NULL. …의 일부 안정 ABI.

PyErr_SetFromErrnoWithFilenameObject()와 유사하지만, 파일명이 C 문자열로 제공됩니다. filename파일시스템 인코딩과 에러 처리기로 디코딩됩니다.

PyObject *PyErr_SetFromWindowsErr(int ierr)
반환값: 항상 NULL. …의 일부 안정 ABI on Windows 버전 3.7 이후로.

OSError를 발생시키는 편의 함수입니다. 0ierr로 호출하면, GetLastError() 호출에서 반환된 에러 코드가 대신 사용됩니다. Win32 함수 FormatMessage()를 호출하여 ierr이나 GetLastError()가 제공하는 에러 코드의 윈도우 설명을 얻은 다음, winerror 어트리뷰트가 에러 코드로 설정되고, strerror 어트리뷰트가 (FormatMessage()에서 얻은) 해당 에러 메시지로 설정된 OSError 객체를 생성한 다음, PyErr_SetObject(PyExc_OSError, object)를 호출합니다. 이 함수는 항상 NULL을 반환합니다.

가용성: Windows.

PyObject *PyErr_SetExcFromWindowsErr(PyObject *type, int ierr)
반환값: 항상 NULL. …의 일부 안정 ABI on Windows 버전 3.7 이후로.

PyErr_SetFromWindowsErr() 와 유사하며, 발생시킬 예외 형을 지정하는 추가 매개 변수가 있습니다.

가용성: Windows.

PyObject *PyErr_SetFromWindowsErrWithFilename(int ierr, const char *filename)
반환값: 항상 NULL. …의 일부 안정 ABI on Windows 버전 3.7 이후로.

PyErr_SetFromWindowsErr()과 유사하지만, filenameNULL이 아니면, 파일 시스템 인코딩으로 디코딩되고 (os.fsdecode()) OSError의 생성자에 세 번째 매개 변수로 전달되어 예외 인스턴스의 filename 어트리뷰트를 정의하는 데 사용되도록 하는 추가 동작이 있습니다.

가용성: Windows.

PyObject *PyErr_SetExcFromWindowsErrWithFilenameObject(PyObject *type, int ierr, PyObject *filename)
반환값: 항상 NULL. …의 일부 안정 ABI on Windows 버전 3.7 이후로.

PyErr_SetExcFromWindowsErr()과 유사하지만, filenameNULL이 아니면, OSError의 생성자에 세 번째 매개 변수로 전달되어 예외 인스턴스의 filename 어트리뷰트를 정의하는 데 사용되도록 하는 추가 동작이 있습니다.

가용성: Windows.

PyObject *PyErr_SetExcFromWindowsErrWithFilenameObjects(PyObject *type, int ierr, PyObject *filename, PyObject *filename2)
반환값: 항상 NULL. …의 일부 안정 ABI on Windows 버전 3.7 이후로.

PyErr_SetExcFromWindowsErrWithFilenameObject()와 유사하지만, 두 번째 파일명 객체를 받아들입니다.

가용성: Windows.

Added in version 3.4.

PyObject *PyErr_SetExcFromWindowsErrWithFilename(PyObject *type, int ierr, const char *filename)
반환값: 항상 NULL. …의 일부 안정 ABI on Windows 버전 3.7 이후로.

PyErr_SetFromWindowsErrWithFilename()와 유사하며, 발생시킬 예외 형을 지정하는 추가 매개 변수가 있습니다.

가용성: Windows.

PyObject *PyErr_SetImportError(PyObject *msg, PyObject *name, PyObject *path)
반환값: 항상 NULL. …의 일부 안정 ABI 버전 3.7 이후로.

ImportError를 발생시키는 편의 함수입니다. msg는 예외의 메시지 문자열로 설정됩니다. 둘 다 NULL이 될 수 있는, namepath는 각각 ImportErrornamepath 어트리뷰트로 설정됩니다.

Added in version 3.3.

PyObject *PyErr_SetImportErrorSubclass(PyObject *exception, PyObject *msg, PyObject *name, PyObject *path)
반환값: 항상 NULL. …의 일부 안정 ABI 버전 3.6 이후로.

PyErr_SetImportError() 와 매우 비슷하지만, 이 함수는 발생시킬 ImportError의 서브 클래스를 지정할 수 있습니다.

Added in version 3.6.

void PyErr_SyntaxLocationObject(PyObject *filename, int lineno, int col_offset)

현재 예외에 대한 파일(file), 줄(line) 및 오프셋(offset) 정보를 설정합니다. 현재 예외가 SyntaxError가 아니면, 추가 어트리뷰트를 설정하여, 예외 인쇄 하위 시스템이 예외가 SyntaxError라고 생각하게 합니다.

Added in version 3.4.

void PyErr_RangedSyntaxLocationObject(PyObject *filename, int lineno, int col_offset, int end_lineno, int end_col_offset)

PyErr_SyntaxLocationObject() 와 유사하지만, 현재 예외에 대한 end_linenoend_col_offset 정보도 설정합니다.

Added in version 3.10.

void PyErr_SyntaxLocationEx(const char *filename, int lineno, int col_offset)
…의 일부 안정 ABI 버전 3.7 이후로.

PyErr_SyntaxLocationObject() 와 비슷하지만, filename파일시스템 인코딩과 에러 처리기로 디코딩되는 바이트 문자열입니다.

Added in version 3.2.

void PyErr_SyntaxLocation(const char *filename, int lineno)
…의 일부 안정 ABI.

PyErr_SyntaxLocationEx() 와 비슷하지만, col_offset 매개 변수는 생략됩니다.

void PyErr_BadInternalCall()
…의 일부 안정 ABI.

이것은 PyErr_SetString(PyExc_SystemError, message)의 줄임 표현입니다. 여기서 message는 내부 연산(예를 들어 파이썬/C API 함수)이 잘못된 인자로 호출되었음을 나타냅니다. 대부분 내부 용입니다.

PyObject *PyErr_ProgramTextObject(PyObject *filename, int lineno)

filenamelineno 줄에 있는 소스 라인을 가져옵니다. filename 은 파이썬 str 객체여야 합니다.

성공 시, 이 함수는 찾은 라인이 포함된 파이썬 문자열 객체를 반환합니다. 실패 시, 예외를 설정하지 않고 NULL 을 반환합니다.

PyObject *PyErr_ProgramText(const char *filename, int lineno)
…의 일부 안정 ABI.

PyErr_ProgramTextObject() 와 유사하지만, filename 이 파이썬 객체 참조 대신 filesystem encoding and error handler 로 디코딩되는 const char* 인 점이 다릅니다.

경고 발행하기

이 함수를 사용하여 C 코드에서 경고를 발행하십시오. 파이썬 warnings 모듈에서 내보낸 유사한 함수를 미러링합니다. 일반적으로 sys.stderr에 경고 메시지를 인쇄합니다; 그러나, 사용자가 경고를 에러로 전환하도록 지정했을 수도 있으며, 이 경우 예외가 발생합니다. 경고 장치의 문제로 인해 이 함수가 예외를 발생시키는 것도 가능합니다. 예외가 발생하지 않으면 반환 값은 0이고, 예외가 발생하면 -1입니다. (경고 메시지가 실제로 인쇄되는지나 예외의 이유를 확인할 수 없습니다; 이것은 의도적입니다.) 예외가 발생하면, 호출자는 정상적인 예외 처리를 수행해야 합니다 (예를 들어, 소유한 참조를 Py_DECREF()하고 에러값을 반환합니다).

int PyErr_WarnEx(PyObject *category, const char *message, Py_ssize_t stack_level)
…의 일부 안정 ABI.

경고 메시지를 발행합니다. category 인자는 경고 범주(아래를 참조하십시오)나 NULL입니다; message 인자는 UTF-8로 인코딩된 문자열입니다. stack_level은 스택 프레임 수를 제공하는 양수입니다; 해당 스택 프레임에서 현재 실행 중인 코드 줄에서 경고가 발생합니다. stack_level이 1이면 PyErr_WarnEx()를 호출하는 함수, 2는 그 위의 함수, 등등.

경고 범주는 PyExc_Warning의 서브 클래스여야 합니다. PyExc_WarningPyExc_Exception의 서브 클래스입니다; 기본 경고 범주는 PyExc_RuntimeWarning입니다. 표준 파이썬 경고 범주는 이름이 경고 유형 에 열거된 전역 변수로 제공됩니다.

경고 제어에 대한 자세한 내용은, warnings 모듈 설명서와 명령 줄 설명서에서 -W 옵션을 참조하십시오. 경고 제어를 위한 C API는 없습니다.

int PyErr_WarnExplicitObject(PyObject *category, PyObject *message, PyObject *filename, int lineno, PyObject *module, PyObject *registry)

모든 경고 어트리뷰트를 명시적으로 제어하면서 경고 메시지를 발행합니다. 이것은 파이썬 함수 warnings.warn_explicit()에 대한 간단한 래퍼입니다; 자세한 내용은 거기를 참조하십시오. 그곳에 설명된 기본 효과를 얻으려면 moduleregistry 인자를 NULL로 설정해야 합니다.

Added in version 3.4.

int PyErr_WarnExplicit(PyObject *category, const char *message, const char *filename, int lineno, const char *module, PyObject *registry)
…의 일부 안정 ABI.

messagemodule이 UTF-8 인코딩된 문자열이고, filename파일시스템 인코딩과 에러 처리기로 디코딩된다는 점을 제외하면 PyErr_WarnExplicitObject() 와 유사합니다.

int PyErr_WarnFormat(PyObject *category, Py_ssize_t stack_level, const char *format, ...)
…의 일부 안정 ABI.

PyErr_WarnEx() 와 유사한 함수이지만, 경고 메시지를 포맷하기 위해 PyUnicode_FromFormat() 을 사용합니다. format 은 ASCII 인코딩된 문자열입니다.

Added in version 3.2.

int PyErr_WarnExplicitFormat(PyObject *category, const char *filename, int lineno, const char *module, PyObject *registry, const char *format, ...)

PyErr_WarnExplicit() 와 유사하지만, 경고 메시지를 포맷하기 위해 PyUnicode_FromFormat() 을 사용합니다. format 은 ASCII 인코딩된 문자열입니다.

Added in version 3.2.

int PyErr_ResourceWarning(PyObject *source, Py_ssize_t stack_level, const char *format, ...)
…의 일부 안정 ABI 버전 3.6 이후로.

PyErr_WarnFormat()과 유사한 함수지만, categoryResourceWarning이고 sourcewarnings.WarningMessage로 전달합니다.

Added in version 3.6.

에러 표시기 조회하기

PyObject *PyErr_Occurred()
반환값: 빌린 참조. …의 일부 안정 ABI.

에러 표시기가 설정되었는지 테스트합니다. 설정되었으면, 예외 type(PyErr_Set* 함수나 PyErr_Restore()에 대한 마지막 호출의 첫 번째 인자)을 반환합니다. 설정되지 않았으면, NULL을 반환합니다. 여러분이 반환 값에 대한 참조를 소유하지 않아서, Py_DECREF() 할 필요가 없습니다.

호출자는 반드시 attached thread state 를 보유해야 합니다.

참고

반환 값을 특정 예외와 비교하지 마십시오; 대신 PyErr_ExceptionMatches()를 사용하십시오, 아래를 참조하십시오. (클래스 예외의 경우 예외가 클래스 대신 인스턴스이거나, 예상하는 예외의 서브 클래스일 수 있어서 비교는 실패하기 쉽습니다.)

int PyErr_ExceptionMatches(PyObject *exc)
…의 일부 안정 ABI.

PyErr_GivenExceptionMatches(PyErr_Occurred(), exc)와 동등합니다. 예외가 실제로 설정되었을 때만 호출해야 합니다; 예외가 발생하지 않았으면 메모리 액세스 위반이 발생합니다.

int PyErr_GivenExceptionMatches(PyObject *given, PyObject *exc)
…의 일부 안정 ABI.

given 예외가 exc의 예외 형과 일치하면 참을 반환합니다. exc가 클래스 객체이면, given이 서브 클래스의 인스턴스일 때도 참을 반환합니다. exc가 튜플이면, 튜플에 있는 모든 예외 형(그리고 서브 튜플도 재귀적으로)을 일치를 위해 검색합니다.

PyObject *PyErr_GetRaisedException(void)
반환값: 새 참조. …의 일부 안정 ABI 버전 3.12 이후로.

현재 발생 중인 예외를 반환하며, 동시에 에러 표시를 지웁니다. 에러 표시가 설정되어 있지 않으면 NULL 을 반환합니다.

이 함수는 예외를 포착해야 하는 코드나 에러 표시기를 일시적으로 저장하고 복원해야 하는 코드에서 사용됩니다.

예를 들어:

{
   PyObject *exc = PyErr_GetRaisedException();

   /* ... 다른 에러를 생성할 수 있는 코드 ... */

   PyErr_SetRaisedException(exc);
}

더 보기

현재 처리 중인 예외를 저장하는 PyErr_GetHandledException().

Added in version 3.12.

void PyErr_SetRaisedException(PyObject *exc)
…의 일부 안정 ABI 버전 3.12 이후로.

exc 를 현재 발생 중인 예외로 설정하며, 기존 예외가 있다면 이를 지웁니다.

경고

이 호출은 유효한 예외여야 하는 exc 의 참조를 가로챕니다(steal).

Added in version 3.12.

void PyErr_Fetch(PyObject **ptype, PyObject **pvalue, PyObject **ptraceback)
…의 일부 안정 ABI.

버전 3.12부터 폐지됨: 대신 PyErr_GetRaisedException() 을 사용하십시오.

주소가 전달된 세 개의 변수로 에러 표시기를 꺼냅니다. 에러 표시기가 설정되지 않았으면, 세 변수를 모두 NULL로 설정합니다. 설정되었으면, 지워지고 꺼낸 각 객체에 대한 참조를 여러분이 소유합니다. 값과 트레이스백 객체는 형 객체가 그렇지 않을 때도 NULL일 수 있습니다.

참고

이 함수는 일반적으로 예외를 포착해야 하거나 에러 표시기를 일시적으로 저장하고 복원해야 하는 레거시 코드에서만 사용됩니다.

예를 들어:

{
   PyObject *type, *value, *traceback;
   PyErr_Fetch(&type, &value, &traceback);

   /* ... 다른 에러를 생성할 수 있는 코드 ... */

   PyErr_Restore(type, value, traceback);
}
void PyErr_Restore(PyObject *type, PyObject *value, PyObject *traceback)
…의 일부 안정 ABI.

버전 3.12부터 폐지됨: 대신 PyErr_SetRaisedException() 을 사용하십시오.

세 객체, type, valuetraceback으로 에러 표시기를 설정합니다. 이미 설정되어 있으면, 기존 예외를 지웁니다. 객체가 NULL이면, 에러 표시기가 지워집니다. NULL type과 함께 NULL이 아닌 value나 traceback 을 전달하지 마십시오. 예외 형은 클래스여야 합니다. 잘못된 예외 형이나 값을 전달하지 마십시오. (이러한 규칙을 위반하면 나중에 미묘한 문제가 발생합니다.) 이 호출은 각 객체에 대한 참조를 제거합니다: 호출 전에 각 객체에 대한 참조를 소유해야 하며 호출 후에는 더는 이러한 참조를 소유하지 않습니다. (이것을 이해할 수 없다면, 이 함수를 사용하지 마십시오. 경고했습니다.)

참고

이 함수는 일반적으로 에러 표시기를 일시적으로 저장하고 복원해야 하는 레거시 코드에서만 사용됩니다. 현재 에러 표시기를 저장하려면 PyErr_Fetch()를 사용하십시오.

void PyErr_NormalizeException(PyObject **exc, PyObject **val, PyObject **tb)
…의 일부 안정 ABI.

버전 3.12부터 폐지됨: 가능한 모든 비정규화(de-normalization)를 방지하기 위해 대신 PyErr_GetRaisedException() 을 사용하십시오.

특정 상황에서, 아래의 PyErr_Fetch()가 반환하는 값은 “비 정규화”되었을 수 있습니다. 즉, *exc는 클래스 객체이지만 *val은 같은 클래스의 인스턴스가 아닙니다. 이 함수는 이 경우 클래스를 인스턴스 화하는 데 사용할 수 있습니다. 값이 이미 정규화되어 있으면, 아무 일도 일어나지 않습니다. 지연된 정규화는 성능 향상을 위해 구현됩니다.

참고

이 함수 예외 값에 __traceback__ 어트리뷰트를 묵시적으로 설정하지 않습니다. 트레이스백을 적절하게 설정해야 하면, 다음과 같은 추가 스니펫이 필요합니다:

if (tb != NULL) {
  PyException_SetTraceback(val, tb);
}
PyObject *PyErr_GetHandledException(void)
…의 일부 안정 ABI 버전 3.11 이후로.

sys.exception()이 반환하는 것과 같은, 활성 예외 인스턴스를 꺼냅니다. 이것은 새로 발생한 예외가 아니라, 이미 포착된 예외를 가리킵니다. 예외에 대한 새 참조나 NULL을 반환합니다. 인터프리터의 예외 상태를 수정하지 않습니다.

참고

이 함수는 일반적으로 예외를 처리하려는 코드에서 사용되지 않습니다. 오히려, 코드가 예외 상태를 임시로 저장하고 복원해야 할 때 사용할 수 있습니다. 예외 상태를 복원하거나 지우려면 PyErr_SetHandledException()를 사용하십시오.

Added in version 3.11.

void PyErr_SetHandledException(PyObject *exc)
…의 일부 안정 ABI 버전 3.11 이후로.

sys.exception()으로 알려진 것과 같은, 활성 예외를 설정합니다. 이것은 새로 발생한 예외가 아니라, 이미 포착된 예외를 가리킵니다. 예외 상태를 지우려면, NULL을 전달하십시오.

참고

이 함수는 일반적으로 예외를 처리하려는 코드에서 사용되지 않습니다. 오히려, 코드가 예외 상태를 임시로 저장하고 복원해야 할 때 사용할 수 있습니다. 예외 상태를 얻으려면 PyErr_GetHandledException()를 사용하십시오.

Added in version 3.11.

void PyErr_GetExcInfo(PyObject **ptype, PyObject **pvalue, PyObject **ptraceback)
…의 일부 안정 ABI 버전 3.7 이후로.

sys.exc_info()로 알려진 것과 같은, 예외 정보의 구식 표현을 꺼냅니다. 이것은 새로 발생한 예외가 아니라, 이미 포착된 예외를 가리킵니다. 세 객체에 대한 새 참조를 반환합니다. 이 중 어느 것이든 NULL일 수 있습니다. 예외 정보 상태를 수정하지 않습니다. 이 함수는 하위 호환성을 위해 유지됩니다. 대신 PyErr_GetHandledException()을 사용하세요.

참고

이 함수는 일반적으로 예외를 처리하려는 코드에서 사용되지 않습니다. 오히려, 코드가 예외 상태를 임시로 저장하고 복원해야 할 때 사용할 수 있습니다. 예외 상태를 복원하거나 지우려면 PyErr_SetExcInfo()를 사용하십시오.

Added in version 3.3.

void PyErr_SetExcInfo(PyObject *type, PyObject *value, PyObject *traceback)
…의 일부 안정 ABI 버전 3.7 이후로.

sys.exc_info()로 알려진 것과 같은, 예외 정보를 설정합니다. 이것은 새로 발생한 예외가 아니라, 이미 포착된 예외를 가리킵니다. 이 함수는 인자의 참조를 훔칩니다. 예외 상태를 지우려면, 세 인자 모두에 NULL을 전달하십시오. 이 함수는 하위 호환성을 위해 유지됩니다. 대신 PyErr_SetHandledException()을 사용하십시오.

참고

이 함수는 일반적으로 예외를 처리하려는 코드에서 사용되지 않습니다. 오히려, 코드가 예외 상태를 임시로 저장하고 복원해야 할 때 사용할 수 있습니다. 예외 상태를 읽으려면 PyErr_GetExcInfo()를 사용하십시오.

Added in version 3.3.

버전 3.11에서 변경: typetraceback 인수는 더 이상 사용되지 않으며 NULL일 수 있습니다. 인터프리터는 이제 이들을 예외 인스턴스(value 인자)로부터 도출합니다. 해당 함수는 여전히 세 인자 모두의 참조를 가로챕니다.

시그널 처리하기

int PyErr_CheckSignals()
…의 일부 안정 ABI.

파이썬 코드를 실행하거나 예외를 발생시키는 것이 안전할 때까지 처리가 지연된 시그널이나 디버거 활성화와 같은 외부 중단을 처리합니다.

예를 들어, Ctrl-C 를 누르면 터미널이 signal.SIGINT 시그널을 전송합니다. 이 함수는 해당 파이썬 시그널 처리기를 실행하며, 기본적으로 이 처리기는 KeyboardInterrupt 예외를 발생시킵니다.

장시간 실행되는 C 코드에서는 사용자가 즉각적으로 반응할 수 있도록 PyErr_CheckSignals() 를 충분히 자주 호출해야 합니다.

이 함수에 의해 호출되는 처리기는 현재 다음을 포함합니다:

  • signal 모듈을 사용하여 등록된 파이썬 함수를 포함한 시그널 처리기.

    시그널 처리기는 메인 인터프리터의 메인 스레드에서만 실행됩니다.

    (이것이 함수가 이름을 얻게 된 배경입니다. 원래 시그널은 인터프리터를 중단할 수 있는 유일한 방법이었습니다.)

  • 필요한 경우 가비지 컬렉터를 실행합니다.

  • 대기 중인 원격 디버거 스크립트를 실행합니다.

  • PyThreadState_SetAsyncExc() 에 의해 설정된 예외를 발생시킵니다.

어떤 처리기라도 예외를 발생시키면, 즉시 해당 예외를 설정하고 -1 을 반환합니다. 나머지 중단은 적절한 경우 다음 PyErr_CheckSignals() 호출 시 처리되도록 남겨둡니다.

모든 처리기가 성공적으로 끝나거나 실행할 처리기가 없는 경우, 0 을 반환합니다.

버전 3.12에서 변경: 이 함수는 이제 가비지 컬렉터를 호출할 수 있습니다.

버전 3.14에서 변경: 원격 디버깅이 활성화된 경우, 이 함수는 이제 원격 디버거 스크립트를 실행할 수 있습니다.

버전 3.15에서 변경: PyThreadState_SetAsyncExc() 에 의해 설정된 예외가 이제 발생합니다.

void PyErr_SetInterrupt()
…의 일부 안정 ABI.

SIGINT 시그널이 도착하는 효과를 시뮬레이션합니다. 이는 PyErr_SetInterruptEx(SIGINT) 와 동일합니다.

참고

이 함수는 async-signal-safe입니다. 이는 attached thread state 없이 호출될 수 있으며, C 시그널 처리기에서도 호출 가능합니다.

int PyErr_SetInterruptEx(int signum)
…의 일부 안정 ABI 버전 3.10 이후로.

시그널 도착의 효과를 시뮬레이션합니다. 다음에 PyErr_CheckSignals()가 호출되면, 주어진 시그널 번호에 대한 파이썬 시그널 처리기가 호출됩니다.

이 함수는 자체 시그널 처리를 설정하고, 인터럽트가 요청될 때(예를 들어 사용자가 작업을 중단하기 위해 Ctrl-C를 누를 때) 파이썬 시그널 처리기가 예상대로 호출되기를 원하는 C 코드에서 호출될 수 있습니다.

주어진 시그널이 파이썬에서 처리되지 않으면 (signal.SIG_DFL이나 signal.SIG_IGN으로 설정되어서), 무시됩니다.

signum 이 허용된 시그널 번호 범위를 벗어나면 -1 을 반환하고, 그렇지 않으면 0 을 반환합니다. 이 함수는 에러 표시를 변경하지 않습니다.

참고

이 함수는 async-signal-safe입니다. 이는 attached thread state 없이 호출될 수 있으며, C 시그널 처리기에서도 호출 가능합니다.

Added in version 3.10.

int PySignal_SetWakeupFd(int fd)

이 유틸리티 함수는 시그널이 수신될 때마다 시그널 번호가 단일 바이트로 기록되는 파일 기술자를 지정합니다. fd는 비 블로킹이어야 합니다. 이전의 파일 기술자를 반환합니다.

-1은 기능을 비활성화합니다; 이것이 초기 상태입니다. 이것은 파이썬의 signal.set_wakeup_fd()와 동등하지만, 에러 검사는 없습니다. fd는 유효한 파일 기술자여야 합니다. 함수는 메인 스레드에서만 호출되어야 합니다.

버전 3.5에서 변경: 윈도우에서, 함수는 이제 소켓 핸들도 지원합니다.

예외 클래스

PyObject *PyErr_NewException(const char *name, PyObject *base, PyObject *dict)
반환값: 새 참조. …의 일부 안정 ABI.

이 유틸리티 함수는 새 예외 클래스를 만들고 반환합니다. name 인자는 새 예외의 이름, module.classname 형식의 C 문자열이어야 합니다. basedict 인자는 일반적으로 NULL입니다. 이렇게 하면 Exception(C에서 PyExc_Exception으로 액세스할 수 있습니다)에서 파생된 클래스 객체가 만들어집니다.

새 클래스의 __module__ 어트리뷰트는 name 인자의 첫 번째 부분(마지막 점까지)으로 설정되고, 클래스 이름은 마지막 부분(마지막 점 뒤)으로 설정됩니다. base 인자는 대체 베이스 클래스를 지정하는 데 사용할 수 있습니다; 하나의 클래스나 클래스의 튜플일 수 있습니다. dict 인자는 클래스 변수와 메서드의 딕셔너리를 지정하는 데 사용할 수 있습니다.

PyObject *PyErr_NewExceptionWithDoc(const char *name, const char *doc, PyObject *base, PyObject *dict)
반환값: 새 참조. …의 일부 안정 ABI.

새로운 예외 클래스에 독스트링을 쉽게 부여할 수 있다는 점을 제외하면 PyErr_NewException()과 같습니다: docNULL이 아니면, 예외 클래스에 대한 독스트링으로 사용됩니다.

Added in version 3.2.

int PyExceptionClass_Check(PyObject *ob)

ob 이 예외 클래스인 경우 0이 아닌 값을 반환하고, 그렇지 않으면 0을 반환합니다. 이 함수는 항상 성공합니다.

const char *PyExceptionClass_Name(PyObject *ob)
…의 일부 안정 ABI 버전 3.8 이후로.

예외 클래스 obtp_name 을 반환합니다.

PyException_HEAD

이것은 예외 객체를 위한 기본 필드를 포함하는 매크로입니다.

이것은 실수로 파이썬 C API에 포함되었으며 확장 프로그램에서 사용하는 것을 위해 설계되지 않았습니다. 사용자 정의 예외 객체를 생성하려면 PyErr_NewException() 을 사용하거나 PyExc_BaseException 을 상속받는 클래스를 생성하십시오.

예외 객체

int PyExceptionInstance_Check(PyObject *op)

opBaseException 의 인스턴스인 경우 참을 반환하고, 그렇지 않으면 거짓을 반환합니다. 이 함수는 항상 성공합니다.

PyExceptionInstance_Class(op)

Py_TYPE(op) 와 동일합니다.

PyObject *PyException_GetTraceback(PyObject *ex)
반환값: 새 참조. …의 일부 안정 ABI.

파이썬에서 __traceback__ 어트리뷰트를 통해 액세스 할 수 있는 새로운 참조로 예외와 관련된 트레이스백을 반환합니다. 관련된 트레이스백이 없으면, NULL을 반환합니다.

int PyException_SetTraceback(PyObject *ex, PyObject *tb)
…의 일부 안정 ABI.

예외와 관련된 트레이스백을 tb로 설정합니다. 지우려면 Py_None을 사용하십시오.

PyObject *PyException_GetContext(PyObject *ex)
반환값: 새 참조. …의 일부 안정 ABI.

파이썬에서 __context__ 어트리뷰트를 통해 액세스 할 수 있는 새 참조로 예외와 연관된 컨텍스트(다른 예외 인스턴스, 이것을 처리하는 도중 ex가 발생했습니다)를 반환합니다. 연결된 컨텍스트가 없으면 NULL을 반환합니다.

void PyException_SetContext(PyObject *ex, PyObject *ctx)
…의 일부 안정 ABI.

예외와 연관된 컨텍스트를 ctx로 설정합니다. 지우려면 NULL을 사용하십시오. ctx가 예외 인스턴스인지 확인하는 형 검사는 없습니다. 이것은 ctx에 대한 참조를 훔칩니다.

PyObject *PyException_GetCause(PyObject *ex)
반환값: 새 참조. …의 일부 안정 ABI.

파이썬에서 __cause__ 어트리뷰트를 통해 액세스 할 수 있는 새 참조로 예외와 관련된 원인(예외 인스턴스나 None, raise ... from ...으로 설정됩니다)을 반환합니다.

void PyException_SetCause(PyObject *ex, PyObject *cause)
…의 일부 안정 ABI.

예외와 관련된 원인을 cause로 설정합니다. 지우려면 NULL을 사용하십시오. cause가 예외 인스턴스나 None인지 확인하는 형 검사는 없습니다. 이것은 cause에 대한 참조를 훔칩니다.

__suppress_context__ 어트리뷰트는 이 함수에 의해 묵시적으로 True로 설정됩니다.

PyObject *PyException_GetArgs(PyObject *ex)
반환값: 새 참조. …의 일부 안정 ABI 버전 3.12 이후로.

예외 exargs 를 반환합니다.

void PyException_SetArgs(PyObject *ex, PyObject *args)
…의 일부 안정 ABI 버전 3.12 이후로.

예외 exargsargs 로 설정합니다.

PyObject *PyUnstable_Exc_PrepReraiseStar(PyObject *orig, PyObject *excs)
이것은 불안정 API. 마이너 릴리스에서 예고 없이 변경될 수 있습니다.

except* 에 대한 인터프리터 구현의 일부를 수행합니다. orig 은 캡처된 원래 예외이고, excs 는 발생시켜야 하는 예외 목록입니다. 이 목록에는 처리되지 않은 orig 의 부분(있는 경우), except* 절에서 발생한 예외(따라서 orig 와 트레이스백이 다름) 및 다시 던져진 예외(따라서 orig 과 동일한 트레이스백을 가짐)가 포함됩니다. 마지막에 재발생시켜야 하는 ExceptionGroup 을 반환하거나, 재발생시킬 것이 없으면 None 을 반환합니다.

Added in version 3.12.

유니코드 예외 객체

다음 함수는 C에서 유니코드 예외를 만들고 수정하는 데 사용됩니다.

PyObject *PyUnicodeDecodeError_Create(const char *encoding, const char *object, Py_ssize_t length, Py_ssize_t start, Py_ssize_t end, const char *reason)
반환값: 새 참조. …의 일부 안정 ABI.

encoding, object, length, start, endreason 어트리뷰트를 사용하여 UnicodeDecodeError 객체를 만듭니다. encodingreason은 UTF-8로 인코딩된 문자열입니다.

PyObject *PyUnicodeDecodeError_GetEncoding(PyObject *exc)
PyObject *PyUnicodeEncodeError_GetEncoding(PyObject *exc)
반환값: 새 참조. …의 일부 안정 ABI.

주어진 예외 객체의 encoding 어트리뷰트를 반환합니다.

PyObject *PyUnicodeDecodeError_GetObject(PyObject *exc)
PyObject *PyUnicodeEncodeError_GetObject(PyObject *exc)
PyObject *PyUnicodeTranslateError_GetObject(PyObject *exc)
반환값: 새 참조. …의 일부 안정 ABI.

주어진 예외 객체의 object 어트리뷰트를 반환합니다.

int PyUnicodeDecodeError_GetStart(PyObject *exc, Py_ssize_t *start)
int PyUnicodeEncodeError_GetStart(PyObject *exc, Py_ssize_t *start)
int PyUnicodeTranslateError_GetStart(PyObject *exc, Py_ssize_t *start)
…의 일부 안정 ABI.

주어진 예외 객체의 start 어트리뷰트를 가져와서 *start에 배치합니다. startNULL이 아니어야 합니다. 성공하면 0을, 실패하면 -1을 반환합니다.

UnicodeError.object`가 시퀀스인 경우, 결과 *start*는 ``0``입니다. 그렇지 않으면 ``[0, len(object) - 1]` 범위로 제한됩니다.

더 보기

UnicodeError.start

int PyUnicodeDecodeError_SetStart(PyObject *exc, Py_ssize_t start)
int PyUnicodeEncodeError_SetStart(PyObject *exc, Py_ssize_t start)
int PyUnicodeTranslateError_SetStart(PyObject *exc, Py_ssize_t start)
…의 일부 안정 ABI.

주어진 예외 객체의 start 어트리뷰트를 start 로 설정합니다. 성공하면 0 을, 실패하면 -1 을 반환합니다.

참고

음수 start 를 전달하는 것이 예외를 발생시키지는 않지만, 해당 getter들은 이를 상대적 오프셋으로 간주하지 않습니다.

int PyUnicodeDecodeError_GetEnd(PyObject *exc, Py_ssize_t *end)
int PyUnicodeEncodeError_GetEnd(PyObject *exc, Py_ssize_t *end)
int PyUnicodeTranslateError_GetEnd(PyObject *exc, Py_ssize_t *end)
…의 일부 안정 ABI.

주어진 예외 객체의 end 어트리뷰트를 가져와서 *end에 배치합니다. endNULL이 아니어야 합니다. 성공하면 0을, 실패하면 -1을 반환합니다.

UnicodeError.object`가 시퀀스인 경우, 결과 *end*는 ``0``입니다. 그렇지 않으면 ``[1, len(object)]` 범위로 제한됩니다.

int PyUnicodeDecodeError_SetEnd(PyObject *exc, Py_ssize_t end)
int PyUnicodeEncodeError_SetEnd(PyObject *exc, Py_ssize_t end)
int PyUnicodeTranslateError_SetEnd(PyObject *exc, Py_ssize_t end)
…의 일부 안정 ABI.

주어진 예외 객체의 end 어트리뷰트를 end로 설정합니다. 성공하면 0을, 실패하면 -1을 반환합니다.

더 보기

UnicodeError.end

PyObject *PyUnicodeDecodeError_GetReason(PyObject *exc)
PyObject *PyUnicodeEncodeError_GetReason(PyObject *exc)
PyObject *PyUnicodeTranslateError_GetReason(PyObject *exc)
반환값: 새 참조. …의 일부 안정 ABI.

주어진 예외 객체의 reason 어트리뷰트를 반환합니다.

int PyUnicodeDecodeError_SetReason(PyObject *exc, const char *reason)
int PyUnicodeEncodeError_SetReason(PyObject *exc, const char *reason)
int PyUnicodeTranslateError_SetReason(PyObject *exc, const char *reason)
…의 일부 안정 ABI.

주어진 예외 객체의 reason 어트리뷰트를 reason으로 설정합니다. 성공하면 0을, 실패하면 -1을 반환합니다.

재귀 제어

이 두 함수는 코어와 확장 모듈 모두에서 C 수준에서 안전한 재귀 호출을 수행하는 방법을 제공합니다. 재귀 코드가 반드시 파이썬 코드를 호출하지 않는 경우 필요합니다 (파이썬 코드는 재귀 깊이를 자동으로 추적합니다). 호출 프로토콜이 재귀 처리를 처리하기 때문에 tp_call 구현에도 필요하지 않습니다.

int Py_EnterRecursiveCall(const char *where)
…의 일부 안정 ABI 버전 3.9 이후로.

재귀적 C 수준 호출이 막 수행되려고 하는 지점을 표시합니다.

그 다음 이 함수는 스택 제한에 도달했는지 확인합니다. 그렇게 되면 RecursionError 가 발생하고 0이 아닌 값이 반환됩니다. 그렇지 않으면 0이 반환됩니다.

where는 재귀 깊이 제한으로 인한 RecursionError 메시지에 이어붙일 " in instance check"와 같은 UTF-8 인코딩된 문자열이어야 합니다.

버전 3.9에서 변경: 이 함수는 이제 제한된 API에서도 사용할 수 있습니다.

void Py_LeaveRecursiveCall(void)
…의 일부 안정 ABI 버전 3.9 이후로.

Py_EnterRecursiveCall() 을 종료합니다. Py_EnterRecursiveCall() 의 각 성공적인 호출마다 한 번씩 호출되어야 합니다.

버전 3.9에서 변경: 이 함수는 이제 제한된 API에서도 사용할 수 있습니다.

컨테이너형에 대해 tp_repr 을 올바르게 구현하려면 특별한 재귀 처리가 필요합니다. 스택을 보호하는 것 외에도, tp_repr 은 순환을 방지하기 위해 객체를 추적해야 합니다. 다음 두 함수가 이 기능을 지원합니다. 사실상, 이들은 @reprlib.recursive_repr 의 C 버전입니다.

int Py_ReprEnter(PyObject *object)
…의 일부 안정 ABI.

순환을 감지하기 위해 tp_repr 구현 시작 시 호출됩니다.

객체가 이미 처리되었으면, 함수는 양의 정수를 반환합니다. 이 경우 tp_repr 구현은 순환을 나타내는 문자열 객체를 반환해야 합니다. 예를 들어, dict 객체는 {...}를 반환하고 list 객체는 [...]를 반환합니다.

재귀 제한에 도달하면 함수는 음의 정수를 반환합니다. 이 경우 tp_repr 구현은 일반적으로 NULL을 반환해야 합니다.

그렇지 않으면, 함수는 0을 반환하고 tp_repr 구현은 정상적으로 계속될 수 있습니다.

void Py_ReprLeave(PyObject *object)
…의 일부 안정 ABI.

Py_ReprEnter()를 종료합니다. 0을 반환하는 Py_ReprEnter() 호출마다 한 번씩 호출해야 합니다.

int Py_GetRecursionLimit(void)
…의 일부 안정 ABI.

현재 인터프리터의 재귀 한계를 가져옵니다. 이는 Py_SetRecursionLimit() 으로 설정할 수 있습니다. 재귀 한계는 파이썬 인터프리터 스택이 무한히 성장하는 것을 방지합니다.

이 함수는 실패할 수 없으며, 호출자는 반드시 attached thread state 를 보유해야 합니다.

void Py_SetRecursionLimit(int new_limit)
…의 일부 안정 ABI.

현재 인터프리터의 재귀 한계를 설정합니다.

이 함수는 실패할 수 없으며, 호출자는 반드시 attached thread state 를 보유해야 합니다.

예외 및 경고 유형

모든 표준 파이썬 예외 및 경고 카테고리는 PyExc_ 뒤에 파이썬 예외 이름이 붙은 전역 변수로 제공됩니다. 이들은 PyObject* 형이며, 모두 클래스 객체입니다.

완전성을 위해 모든 변수를 나열합니다:

예외 유형

C 이름

파이썬 이름

PyObject *PyExc_BaseException
…의 일부 안정 ABI.

BaseException

PyObject *PyExc_BaseExceptionGroup
…의 일부 안정 ABI 버전 3.11 이후로.

BaseExceptionGroup

PyObject *PyExc_Exception
…의 일부 안정 ABI.

Exception

PyObject *PyExc_ArithmeticError
…의 일부 안정 ABI.

ArithmeticError

PyObject *PyExc_AssertionError
…의 일부 안정 ABI.

AssertionError

PyObject *PyExc_AttributeError
…의 일부 안정 ABI.

AttributeError

PyObject *PyExc_BlockingIOError
…의 일부 안정 ABI 버전 3.7 이후로.

BlockingIOError

PyObject *PyExc_BrokenPipeError
…의 일부 안정 ABI 버전 3.7 이후로.

BrokenPipeError

PyObject *PyExc_BufferError
…의 일부 안정 ABI.

BufferError

PyObject *PyExc_ChildProcessError
…의 일부 안정 ABI 버전 3.7 이후로.

ChildProcessError

PyObject *PyExc_ConnectionAbortedError
…의 일부 안정 ABI 버전 3.7 이후로.

ConnectionAbortedError

PyObject *PyExc_ConnectionError
…의 일부 안정 ABI 버전 3.7 이후로.

ConnectionError

PyObject *PyExc_ConnectionRefusedError
…의 일부 안정 ABI 버전 3.7 이후로.

ConnectionRefusedError

PyObject *PyExc_ConnectionResetError
…의 일부 안정 ABI 버전 3.7 이후로.

ConnectionResetError

PyObject *PyExc_EOFError
…의 일부 안정 ABI.

EOFError

PyObject *PyExc_FileExistsError
…의 일부 안정 ABI 버전 3.7 이후로.

FileExistsError

PyObject *PyExc_FileNotFoundError
…의 일부 안정 ABI 버전 3.7 이후로.

FileNotFoundError

PyObject *PyExc_FloatingPointError
…의 일부 안정 ABI.

FloatingPointError

PyObject *PyExc_GeneratorExit
…의 일부 안정 ABI.

GeneratorExit

PyObject *PyExc_ImportCycleError

ImportCycleError

PyObject *PyExc_ImportError
…의 일부 안정 ABI.

ImportError

PyObject *PyExc_IndentationError
…의 일부 안정 ABI.

IndentationError

PyObject *PyExc_IndexError
…의 일부 안정 ABI.

IndexError

PyObject *PyExc_InterruptedError
…의 일부 안정 ABI 버전 3.7 이후로.

InterruptedError

PyObject *PyExc_IsADirectoryError
…의 일부 안정 ABI 버전 3.7 이후로.

IsADirectoryError

PyObject *PyExc_KeyError
…의 일부 안정 ABI.

KeyError

PyObject *PyExc_KeyboardInterrupt
…의 일부 안정 ABI.

KeyboardInterrupt

PyObject *PyExc_LookupError
…의 일부 안정 ABI.

LookupError

PyObject *PyExc_MemoryError
…의 일부 안정 ABI.

MemoryError

PyObject *PyExc_ModuleNotFoundError
…의 일부 안정 ABI 버전 3.6 이후로.

ModuleNotFoundError

PyObject *PyExc_NameError
…의 일부 안정 ABI.

NameError

PyObject *PyExc_NotADirectoryError
…의 일부 안정 ABI 버전 3.7 이후로.

NotADirectoryError

PyObject *PyExc_NotImplementedError
…의 일부 안정 ABI.

NotImplementedError

PyObject *PyExc_OSError
…의 일부 안정 ABI.

OSError

PyObject *PyExc_OverflowError
…의 일부 안정 ABI.

OverflowError

PyObject *PyExc_PermissionError
…의 일부 안정 ABI 버전 3.7 이후로.

PermissionError

PyObject *PyExc_ProcessLookupError
…의 일부 안정 ABI 버전 3.7 이후로.

ProcessLookupError

PyObject *PyExc_PythonFinalizationError

PythonFinalizationError

PyObject *PyExc_RecursionError
…의 일부 안정 ABI 버전 3.7 이후로.

RecursionError

PyObject *PyExc_ReferenceError
…의 일부 안정 ABI.

ReferenceError

PyObject *PyExc_RuntimeError
…의 일부 안정 ABI.

RuntimeError

PyObject *PyExc_StopAsyncIteration
…의 일부 안정 ABI 버전 3.7 이후로.

StopAsyncIteration

PyObject *PyExc_StopIteration
…의 일부 안정 ABI.

StopIteration

PyObject *PyExc_SyntaxError
…의 일부 안정 ABI.

SyntaxError

PyObject *PyExc_SystemError
…의 일부 안정 ABI.

SystemError

PyObject *PyExc_SystemExit
…의 일부 안정 ABI.

SystemExit

PyObject *PyExc_TabError
…의 일부 안정 ABI.

TabError

PyObject *PyExc_TimeoutError
…의 일부 안정 ABI 버전 3.7 이후로.

TimeoutError

PyObject *PyExc_TypeError
…의 일부 안정 ABI.

TypeError

PyObject *PyExc_UnboundLocalError
…의 일부 안정 ABI.

UnboundLocalError

PyObject *PyExc_UnicodeDecodeError
…의 일부 안정 ABI.

UnicodeDecodeError

PyObject *PyExc_UnicodeEncodeError
…의 일부 안정 ABI.

UnicodeEncodeError

PyObject *PyExc_UnicodeError
…의 일부 안정 ABI.

UnicodeError

PyObject *PyExc_UnicodeTranslateError
…의 일부 안정 ABI.

UnicodeTranslateError

PyObject *PyExc_ValueError
…의 일부 안정 ABI.

ValueError

PyObject *PyExc_ZeroDivisionError
…의 일부 안정 ABI.

ZeroDivisionError

Added in version 3.5: PyExc_StopAsyncIterationPyExc_RecursionError.

Added in version 3.6: PyExc_ModuleNotFoundError.

Added in version 3.11: PyExc_BaseExceptionGroup.

OSError 별칭

다음은 PyExc_OSError 에 대한 호환성 별칭입니다.

버전 3.3에서 변경: 이러한 별칭은 별도의 예외 형이었습니다.

C 이름

파이썬 이름

노트

PyObject *PyExc_EnvironmentError
…의 일부 안정 ABI.

OSError

PyObject *PyExc_IOError
…의 일부 안정 ABI.

OSError

PyObject *PyExc_WindowsError
…의 일부 안정 ABI on Windows 버전 3.7 이후로.

OSError

[win]

노트:

[win]

PyExc_WindowsError 는 윈도우에서만 정의됩니다. 이 변수를 사용하는 코드는 전처리 매크로 MS_WINDOWS 가 정의되어 있는지 확인하여 보호하십시오.

경고 유형

C 이름

파이썬 이름

PyObject *PyExc_Warning
…의 일부 안정 ABI.

Warning

PyObject *PyExc_BytesWarning
…의 일부 안정 ABI.

BytesWarning

PyObject *PyExc_DeprecationWarning
…의 일부 안정 ABI.

DeprecationWarning

PyObject *PyExc_EncodingWarning
…의 일부 안정 ABI 버전 3.10 이후로.

EncodingWarning

PyObject *PyExc_FutureWarning
…의 일부 안정 ABI.

FutureWarning

PyObject *PyExc_ImportWarning
…의 일부 안정 ABI.

ImportWarning

PyObject *PyExc_PendingDeprecationWarning
…의 일부 안정 ABI.

PendingDeprecationWarning

PyObject *PyExc_ResourceWarning
…의 일부 안정 ABI 버전 3.7 이후로.

ResourceWarning

PyObject *PyExc_RuntimeWarning
…의 일부 안정 ABI.

RuntimeWarning

PyObject *PyExc_SyntaxWarning
…의 일부 안정 ABI.

SyntaxWarning

PyObject *PyExc_UnicodeWarning
…의 일부 안정 ABI.

UnicodeWarning

PyObject *PyExc_UserWarning
…의 일부 안정 ABI.

UserWarning

Added in version 3.2: PyExc_ResourceWarning.

Added in version 3.10: PyExc_EncodingWarning.

트레이스백

PyTypeObject PyTraceBack_Type
…의 일부 안정 ABI.

트레이스백 객체의 타입 객체입니다. 파이썬 레이어에서는 types.TracebackType 으로 사용할 수 있습니다.

int PyTraceBack_Check(PyObject *op)

op 이 트레이스백 객체인 경우 참을 반환하고, 그렇지 않으면 거짓을 반환합니다. 이 함수는 하위 유형을 고려하지 않습니다.

int PyTraceBack_Here(PyFrameObject *f)
…의 일부 안정 ABI.

현재 예외의 __traceback__ 어트리뷰트를 기존 체인에 f 를 추가한 새 트레이스백으로 교체합니다.

예외가 설정되지 않은 상태에서 이 함수를 호출하는 것은 정의되지 않은 동작입니다.

이 함수는 성공 시 0 을 반환하고, 실패 시 예외를 설정하며 -1 을 반환합니다.

int PyTraceBack_Print(PyObject *tb, PyObject *f)
…의 일부 안정 ABI.

트레이스백 tb 을 파일 f 에 기록합니다.

이 함수는 성공 시 0 을 반환하고, 실패 시 예외를 설정하며 -1 을 반환합니다.

const char *PyUnstable_DumpTraceback(int fd, PyThreadState *tstate)
이것은 불안정 API. 마이너 릴리스에서 예고 없이 변경될 수 있습니다.

tstate 내 파이썬 스택의 트레이스를 파일 fd 에 기록합니다. 형식은 다음과 같습니다:

Traceback (most recent call first):
  File "xxx", line xxx in <xxx>
  File "xxx", line xxx in <xxx>
  ...
  File "xxx", line xxx in <xxx>

이 함수는 세그폴트(segfault), 치명적 오류 등과 같은 상황을 디버깅하기 위한 용도입니다. 출력되는 파일 및 함수 이름은 backslashreplace를 사용하여 ASCII로 인코딩되고 500자로 제한됩니다. 처음 100개의 프레임만 기록하며, 그 이상의 프레임은 ... 으로 생략됩니다.

이 함수는 성공 시 NULL 을 반환하고, 오류 발생 시 오류 메시지를 반환합니다.

이 함수는 인터프리터가 일관성 없는 상태일 수 있는 SIGSEGV 시그널 핸들러와 같은 충돌 시나리오에서 사용하도록 설계되었습니다. 일부만 수정된 인터프리터 데이터 구조를 읽기 때문에, 이 함수는 불완전한 출력을 생성하거나 자체적으로 충돌할 수 있습니다.

호출자는 attached thread state 를 보유할 필요가 없으며, tstate 또한 연결(attached)될 필요가 없습니다.

Added in version 3.15.

const char *PyUnstable_DumpTracebackThreads(int fd, PyInterpreterState *interp, PyThreadState *current_tstate, Py_ssize_t max_threads)
이것은 불안정 API. 마이너 릴리스에서 예고 없이 변경될 수 있습니다.

interp 에 있는 모든 파이썬 스레드의 트레이스를 파일 fd 에 기록합니다.

interpNULL 인 경우 이 함수는 스레드 특정 저장소(thread-specific storage)를 사용하여 현재 인터프리터를 식별하려고 시도합니다. 식별에 실패하면 오류를 반환합니다.

current_tstateNULL 이 아니면 이를 사용하여 기록되는 출력에서 현재 스레드를 식별합니다. NULL 인 경우 이 함수는 스레드 특정 저장소를 사용하여 현재 스레드를 식별합니다. 이 함수가 현재 파이썬 스레드 상태를 가져오지 못하더라도 오류로 간주하지 않습니다.

이 함수는 성공 시 NULL 을 반환하고, 오류 발생 시 오류 메시지를 반환합니다.

이 함수는 세그폴트(segfault), 치명적 오류 등과 같은 상황을 디버깅하기 위한 용도입니다. 각 스레드에 대해 PyUnstable_DumpTraceback() 을 호출합니다. 처음 max_threads 개의 스레드에 대한 트레이스백만 기록하며, 그 이상의 출력은 ... 으로 생략됩니다. max_threads 가 0인 경우 이 함수는 인자로 100이라는 기본값을 사용합니다.

이 함수는 인터프리터가 일관성 없는 상태일 수 있는 SIGSEGV 시그널 핸들러와 같은 충돌 시나리오에서 사용하도록 설계되었습니다. 일부만 수정된 인터프리터 데이터 구조를 읽기 때문에, 이 함수는 불완전한 출력을 생성하거나 자체적으로 충돌할 수 있습니다.

호출자는 attached thread state 를 보유할 필요가 없으며, current_tstate 또한 연결(attached)될 필요가 없습니다.

경고

free-threaded build 에서 이 함수는 스레드 안전(thread-safe)하지 않습니다. 이 함수가 호출되는 동안 다른 스레드가 자신의 thread state 를 삭제하면 프로세스가 충돌할 가능성이 높습니다.

Added in version 3.15.

분실물 보관소