매핑 프로토콜

PyObject_GetItem(), PyObject_SetItem()PyObject_DelItem()도 참조하십시오.

int PyMapping_Check(PyObject *o)

객체가 매핑 프로토콜을 제공하거나 슬라이싱을 지원하면 1을 반환하고, 그렇지 않으면 0을 반환합니다. __getitem__() 메서드가 있는 파이썬 클래스의 경우 1을 반환한다는 점에 유의하십시오; 일반적으로 지원하는 키 형을 판단할 수 없기 때문입니다. 이 함수는 항상 성공합니다.

Py_ssize_t PyMapping_Size(PyObject *o)
Py_ssize_t PyMapping_Length(PyObject *o)

성공 시 객체 o의 키 수를 반환하고, 실패하면 -1을 반환합니다. 이는 파이썬 표현식 len(o)와 동등합니다.

PyObject* PyMapping_GetItemString(PyObject *o, const char *key)
Return value: New reference.

문자열 key에 해당하는 o의 요소나 실패 시 NULL을 반환합니다. 이는 파이썬 표현식 o[key]와 동등합니다. PyObject_GetItem()도 참조하십시오.

int PyMapping_SetItemString(PyObject *o, const char *key, PyObject *v)

객체 o에서 문자열 key를 값 v에 매핑합니다. 실패하면 -1을 반환합니다. 이것은 파이썬 문장 o[key] = v와 동등합니다. PyObject_SetItem()도 참조하십시오. 이 함수는 v에 대한 참조를 훔치지 않습니다.

int PyMapping_DelItem(PyObject *o, PyObject *key)

객체 o에서 객체 key에 대한 매핑을 제거합니다. 실패하면 -1을 반환합니다. 이것은 파이썬 문장 del o[key]와 동등합니다. 이것은 PyObject_DelItem()의 별칭입니다.

int PyMapping_DelItemString(PyObject *o, const char *key)

객체 o에서 문자열 key에 대한 매핑을 제거합니다. 실패하면 -1을 반환합니다. 이것은 파이썬 문장 del o[key]와 동등합니다.

int PyMapping_HasKey(PyObject *o, PyObject *key)

매핑 객체에 key 키가 있으면 1을 반환하고, 그렇지 않으면 0을 반환합니다. 이는 파이썬 표현식 key in o와 동등합니다. 이 함수는 항상 성공합니다.

__getitem__() 메서드를 호출하는 동안 발생하는 예외는 억제됨에 유의하십시오. 에러 보고를 받으려면 대신 PyObject_GetItem()을 사용하십시오.

int PyMapping_HasKeyString(PyObject *o, const char *key)

매핑 객체에 key 키가 있으면 1을 반환하고, 그렇지 않으면 0을 반환합니다. 이는 파이썬 표현식 key in o와 동등합니다. 이 함수는 항상 성공합니다.

__getitem__() 메서드를 호출하고 임시 문자열 객체를 만드는 동안 발생하는 예외는 억제됨에 유의하십시오. 에러 보고를 받으려면 대신 PyMapping_GetItemString()을 사용하십시오.

PyObject* PyMapping_Keys(PyObject *o)
Return value: New reference.

성공하면, 객체 o의 키 리스트를 반환합니다. 실패하면, NULL을 반환합니다.

버전 3.7에서 변경: 이전에는 함수가 리스트나 튜플을 반환했습니다.

PyObject* PyMapping_Values(PyObject *o)
Return value: New reference.

성공하면, 객체 o의 값 리스트를 반환합니다. 실패하면, NULL을 반환합니다.

버전 3.7에서 변경: 이전에는 함수가 리스트나 튜플을 반환했습니다.

PyObject* PyMapping_Items(PyObject *o)
Return value: New reference.

성공하면, 객체 o에 있는 항목 리스트를 반환합니다. 여기서 각 항목은 키-값 쌍을 포함하는 튜플입니다. 실패하면, NULL을 반환합니다.

버전 3.7에서 변경: 이전에는 함수가 리스트나 튜플을 반환했습니다.