Протокол картирования

См. также PyObject_GetItem(), PyObject_SetItem() и PyObject_DelItem().

int PyMapping_Check(PyObject *o)
Part of the Stable ABI.

Возвращает 1, если объект обеспечивает протокол отображения или поддерживает нарезку, и 0 в противном случае. Обратите внимание, что она возвращает 1 для классов Python с методом __getitem__(), поскольку в общем случае невозможно определить, какой тип ключей поддерживает класс. Эта функция всегда успешна.

Py_ssize_t PyMapping_Size(PyObject *o)
Py_ssize_t PyMapping_Length(PyObject *o)
Part of the Stable ABI.

Возвращает количество ключей в объекте o в случае успеха и -1 в случае неудачи. Это эквивалентно выражению Python len(o).

PyObject *PyMapping_GetItemString(PyObject *o, const char *key)
Return value: New reference. Part of the Stable ABI.

Возвращает элемент o, соответствующий строке key или NULL при неудаче. Это эквивалент выражения Python o[key]. См. также PyObject_GetItem().

int PyMapping_SetItemString(PyObject *o, const char *key, PyObject *v)
Part of the Stable ABI.

Сопоставить строку key со значением v в объекте o. При неудаче возвращает -1. Это эквивалент оператора Python o[key] = v. См. также PyObject_SetItem(). Эта функция не крадет ссылку на v.

int PyMapping_DelItem(PyObject *o, PyObject *key)

Удалить отображение для объекта key из объекта o. При неудаче возвращается -1. Это эквивалентно оператору Python del o[key]. Это псевдоним оператора PyObject_DelItem().

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

Удалить отображение для строки key из объекта o. При неудаче возвращается -1. Это эквивалентно оператору Python del o[key].

int PyMapping_HasKey(PyObject *o, PyObject *key)
Part of the Stable ABI.

Возвращает 1, если объект отображения имеет ключ key и 0 в противном случае. Это эквивалентно выражению Python key in o. Эта функция всегда успешна.

Обратите внимание, что исключения, возникающие при вызове метода __getitem__(), будут подавлены. Для получения сообщений об ошибках используйте PyObject_GetItem() вместо этого.

int PyMapping_HasKeyString(PyObject *o, const char *key)
Part of the Stable ABI.

Возвращает 1, если объект отображения имеет ключ key и 0 в противном случае. Это эквивалентно выражению Python key in o. Эта функция всегда успешна.

Обратите внимание, что исключения, возникающие при вызове метода __getitem__() и создании временного строкового объекта, будут подавлены. Для получения сообщений об ошибках используйте PyMapping_GetItemString() вместо этого.

PyObject *PyMapping_Keys(PyObject *o)
Return value: New reference. Part of the Stable ABI.

При успехе возвращает список ключей в объекте o. При неудаче возвращается NULL.

Изменено в версии 3.7: Ранее функция возвращала список или кортеж.

PyObject *PyMapping_Values(PyObject *o)
Return value: New reference. Part of the Stable ABI.

При успехе возвращает список значений в объекте o. При неудаче возвращается NULL.

Изменено в версии 3.7: Ранее функция возвращала список или кортеж.

PyObject *PyMapping_Items(PyObject *o)
Return value: New reference. Part of the Stable ABI.

При успехе возвращает список элементов объекта o, где каждый элемент - кортеж, содержащий пару ключ-значение. В случае неудачи возвращается NULL.

Изменено в версии 3.7: Ранее функция возвращала список или кортеж.

Вернуться на верх