함수 객체

파이썬 함수와 관련된 몇 가지 함수가 있습니다.

PyFunctionObject

함수에 사용되는 C 구조체.

PyTypeObject PyFunction_Type

이것은 PyTypeObject의 인스턴스이며 파이썬 함수 형을 나타냅니다. 파이썬 프로그래머에게 types.FunctionType으로 노출됩니다.

int PyFunction_Check(PyObject *o)

o가 함수 객체(PyFunction_Type 형)면 참을 반환합니다. 매개 변수는 NULL이 아니어야 합니다. 이 함수는 항상 성공합니다.

PyObject* PyFunction_New(PyObject *code, PyObject *globals)
Return value: New reference.

코드 객체 code와 연관된 새 함수 객체를 반환합니다. globals는 함수에서 액세스할 수 있는 전역 변수가 있는 딕셔너리이어야 합니다.

함수의 독스트링과 이름은 코드 객체에서 가져옵니다. __module__globals에서 가져옵니다. 인자 기본값, 어노테이션 및 클로저는 NULL로 설정됩니다. __qualname__은 함수의 이름과 같은 값으로 설정됩니다.

PyObject* PyFunction_NewWithQualName(PyObject *code, PyObject *globals, PyObject *qualname)
Return value: New reference.

PyFunction_New()와 비슷하지만, 함수 객체의 __qualname__ 어트리뷰트를 설정할 수도 있도록 합니다. qualname는 유니코드 객체나 NULL이어야 합니다; NULL이면, __qualname__ 어트리뷰트는 __name__ 어트리뷰트와 같은 값으로 설정됩니다.

버전 3.3에 추가.

PyObject* PyFunction_GetCode(PyObject *op)
Return value: Borrowed reference.

함수 객체 op와 연관된 코드 객체를 반환합니다.

PyObject* PyFunction_GetGlobals(PyObject *op)
Return value: Borrowed reference.

함수 객체 op와 연관된 전역 딕셔너리를 반환합니다.

PyObject* PyFunction_GetModule(PyObject *op)
Return value: Borrowed reference.

함수 객체 op__module__ 어트리뷰트를 반환합니다. 이것은 일반적으로 모듈 이름을 포함하는 문자열이지만, 파이썬 코드로 다른 객체로 설정할 수 있습니다.

PyObject* PyFunction_GetDefaults(PyObject *op)
Return value: Borrowed reference.

함수 객체 op의 인자 기본값을 반환합니다. 이는 인자의 튜플이나 NULL일 수 있습니다.

int PyFunction_SetDefaults(PyObject *op, PyObject *defaults)

함수 객체 op의 인자 기본값을 설정합니다. defaultsPy_None 이나 튜플이어야 합니다.

실패하면 SystemError를 발생시키고 -1을 반환합니다.

PyObject* PyFunction_GetClosure(PyObject *op)
Return value: Borrowed reference.

함수 객체 op와 연관된 클로저를 반환합니다. 이것은 NULL 이나 셀 객체의 튜플일 수 있습니다.

int PyFunction_SetClosure(PyObject *op, PyObject *closure)

함수 객체 op와 연관된 클로저를 설정합니다. closurePy_None 이나 셀 객체의 튜플이어야 합니다.

실패하면 SystemError를 발생시키고 -1을 반환합니다.

PyObject *PyFunction_GetAnnotations(PyObject *op)
Return value: Borrowed reference.

함수 객체 op의 어노테이션을 반환합니다. 이것은 가변 딕셔너리나 NULL 일 수 있습니다.

int PyFunction_SetAnnotations(PyObject *op, PyObject *annotations)

함수 객체 op의 어노테이션을 설정합니다. annotations은 딕셔너리나 Py_None 이어야 합니다.

실패하면 SystemError를 발생시키고 -1을 반환합니다.