Протокол последовательности¶
-
int PySequence_Check(PyObject *o)¶
- Part of the Стабильный ABI.
Возвращает
1, если объект предоставляет протокол последовательности, и0в противном случае. Обратите внимание, что она возвращает1для классов Python с методом__getitem__(), если только они не являются подклассамиdict, поскольку в общем случае невозможно определить, какой тип ключей поддерживает класс. Эта функция всегда выполняется успешно.
-
Py_ssize_t PySequence_Size(PyObject *o)¶
-
Py_ssize_t PySequence_Length(PyObject *o)¶
- Part of the Стабильный ABI.
Возвращает количество объектов в последовательности o в случае успеха и
-1в случае неудачи. Это эквивалентно выражению Pythonlen(o).
-
PyObject *PySequence_Concat(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает объединение o1 и o2 в случае успеха и
NULLв случае неудачи. Это эквивалент выражения Pythono1 + o2.
-
PyObject *PySequence_Repeat(PyObject *o, Py_ssize_t count)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат повторения объекта sequence o count раз или
NULLв случае сбоя. Это эквивалент выражения Pythono * count.
-
PyObject *PySequence_InPlaceConcat(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает объединение o1 и o2 в случае успеха и
NULLв случае неудачи. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент выражения Pythono1 += o2.
-
PyObject *PySequence_InPlaceRepeat(PyObject *o, Py_ssize_t count)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат повторения объекта sequence o*количество раз или ``NULL`` в случае сбоя. Операция выполняется *на месте, если o поддерживает ее. Это эквивалент выражения Python
o *= count.
-
PyObject *PySequence_GetItem(PyObject *o, Py_ssize_t i)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает i-й элемент из o или
NULLв случае сбоя. Это эквивалент выражения Pythono[i].
-
PyObject *PySequence_GetSlice(PyObject *o, Py_ssize_t i1, Py_ssize_t i2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает фрагмент объекта sequence o между i1 и i2 или
NULLв случае сбоя. Это эквивалент выражения Pythono[i1:i2].
-
int PySequence_SetItem(PyObject *o, Py_ssize_t i, PyObject *v)¶
- Part of the Стабильный ABI.
Назначьте объект v i-му элементу o. Вызовите исключение и верните
-1в случае сбоя; верните0в случае успеха. Это эквивалентно инструкции Pythono[i] = v. Эта функция не крадет ссылку на v.Если v равно
NULL, элемент удаляется, но эта функция считается устаревшей в пользу использованияPySequence_DelItem().
-
int PySequence_DelItem(PyObject *o, Py_ssize_t i)¶
- Part of the Стабильный ABI.
Удалите i-й элемент object o. В случае сбоя возвращает
-1. Это эквивалентно инструкции Pythondel o[i].
-
int PySequence_SetSlice(PyObject *o, Py_ssize_t i1, Py_ssize_t i2, PyObject *v)¶
- Part of the Стабильный ABI.
Присвойте объект последовательности v фрагменту в объекте последовательности o от i1 до i2. Это эквивалентно инструкции Python
o[i1:i2] = v.
-
int PySequence_DelSlice(PyObject *o, Py_ssize_t i1, Py_ssize_t i2)¶
- Part of the Стабильный ABI.
Удалите фрагмент в объекте последовательности o от i1 до i2. В случае сбоя возвращает
-1. Это эквивалентно инструкции Pythondel o[i1:i2].
-
Py_ssize_t PySequence_Count(PyObject *o, PyObject *value)¶
- Part of the Стабильный ABI.
Возвращает количество вхождений value в o, то есть возвращает количество ключей, для которых
o[key] == value. В случае сбоя возвращает-1. Это эквивалентно выражению Pythono.count(value).
-
int PySequence_Contains(PyObject *o, PyObject *value)¶
- Part of the Стабильный ABI.
Определите, содержит ли o значение. Если элемент в o равен value, верните
1, в противном случае верните0. В случае ошибки верните-1. Это эквивалентно выражению Pythonvalue in o.
-
Py_ssize_t PySequence_Index(PyObject *o, PyObject *value)¶
- Part of the Стабильный ABI.
Возвращает первый индекс i, для которого
o[i] == value. В случае ошибки возвращает-1. Это эквивалентно выражению Pythono.index(value).
-
PyObject *PySequence_List(PyObject *o)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает объект list с тем же содержимым, что и sequence или iterable o, или
NULLв случае сбоя. Гарантированно, что возвращаемый список будет новым. Это эквивалентно выражению Pythonlist(o).
-
PyObject *PySequence_Tuple(PyObject *o)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает объект tuple с тем же содержимым, что и sequence или iterable o, или
NULLв случае сбоя. Если o является кортежем, будет возвращена новая ссылка, в противном случае будет создан кортеж с соответствующим содержимым. Это эквивалентно выражению Pythontuple(o).
-
PyObject *PySequence_Fast(PyObject *o, const char *m)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает последовательность или итерацию o в качестве объекта, используемого другим семейством функций
PySequence_Fast*. Если объект не является последовательностью или итерацией, вызываетTypeErrorс m в качестве текста сообщения. ВозвращаетNULLпри сбое.Функции
PySequence_Fast*названы таким образом, потому что они предполагают, что o - это aPyTupleObjectили aPyListObjectи получают прямой доступ к полям данных o.В качестве детали реализации CPython, если o уже является последовательностью или списком, оно будет возвращено.
-
Py_ssize_t PySequence_Fast_GET_SIZE(PyObject *o)¶
Возвращает длину o, предполагая, что o было возвращено с помощью
PySequence_Fast()и что o не являетсяNULL. Размер также можно получить, вызвавPySequence_Size()для o, ноPySequence_Fast_GET_SIZE()работает быстрее, поскольку может предполагать, что o - это список или кортеж.
-
PyObject *PySequence_Fast_GET_ITEM(PyObject *o, Py_ssize_t i)¶
- Возвращаемое значение: Заимствованная ссылка.
Возвращает i-й элемент o, предполагая, что o был возвращен с помощью
PySequence_Fast(), o не являетсяNULLи что i находится в пределах допустимых значений.
-
PyObject **PySequence_Fast_ITEMS(PyObject *o)¶
Возвращает базовый массив указателей на PyObject. Предполагается, что o было возвращено с помощью
PySequence_Fast(), а o не являетсяNULL.Обратите внимание, что при изменении размера списка при перераспределении может произойти перемещение массива элементов. Поэтому используйте указатель на базовый массив только в тех контекстах, где последовательность не может измениться.
-
PyObject *PySequence_ITEM(PyObject *o, Py_ssize_t i)¶
- Возвращаемое значение: Новая ссылка.
Возвращает i-й элемент из o или
NULLв случае сбоя. Более быстрая формаPySequence_GetItem(), но без проверки того, чтоPySequence_Check()на o является истинным и без корректировки на отрицательные индексы.