Протокол отображения

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

int PyMapping_Check(PyObject *o)
Part of the Стабильный ABI.

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

Py_ssize_t PyMapping_Size(PyObject *o)
Py_ssize_t PyMapping_Length(PyObject *o)
Part of the Стабильный ABI.

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

PyObject *PyMapping_GetItemString(PyObject *o, const char *key)
Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.

Это то же самое, что и PyObject_GetItem(), но ключ указан как строка const char* в кодировке UTF-8 байт, а не как PyObject*.

int PyMapping_SetItemString(PyObject *o, const char *key, PyObject *v)
Part of the Стабильный ABI.

Это то же самое, что и PyObject_SetItem(), но ключ указан как строка const char* в кодировке UTF-8 байт, а не как PyObject*.

int PyMapping_DelItem(PyObject *o, PyObject *key)

Это псевдоним : c:func:PyObject_DelItem.

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

Это то же самое, что и PyObject_DelItem(), но ключ указан как строка const char* в кодировке UTF-8 байт, а не как PyObject*.

int PyMapping_HasKey(PyObject *o, PyObject *key)
Part of the Стабильный ABI.

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

Примечание

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

int PyMapping_HasKeyString(PyObject *o, const char *key)
Part of the Стабильный ABI.

Это то же самое, что и PyMapping_HasKey(), но ключ указан как строка const char* в кодировке UTF-8 байт, а не как PyObject*.

Примечание

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

PyObject *PyMapping_Keys(PyObject *o)
Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.

В случае успеха верните список ключей в object o. В случае неудачи верните NULL.

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

PyObject *PyMapping_Values(PyObject *o)
Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.

В случае успеха верните список значений в object o. В случае неудачи верните NULL.

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

PyObject *PyMapping_Items(PyObject *o)
Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.

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

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

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