Protocolo iterador¶
Hay dos funciones específicas para trabajar con iteradores.
-
int PyIter_Check(PyObject *o)¶
- Part of the Stable ABI since version 3.8.
Return non-zero if the object o can be safely passed to
PyIter_NextItem()and0otherwise. This function always succeeds.
-
int PyAIter_Check(PyObject *o)¶
- Part of the Stable ABI since version 3.10.
Retorna un valor distinto de cero si el objeto o proporciona el protocolo
AsyncIterator, y0en caso contrario. Esta función siempre tiene éxito.Added in version 3.10.
-
int PyIter_NextItem(PyObject *iter, PyObject **item)¶
- Part of the Stable ABI since version 3.14.
Return
1and set item to a strong reference of the next value of the iterator iter on success. Return0and set item toNULLif there are no remaining values. Return-1, set item toNULLand set an exception on error.Added in version 3.14.
-
PyObject *PyIter_Next(PyObject *o)¶
- Return value: New reference. Part of the Stable ABI.
This is an older version of
PyIter_NextItem(), which is retained for backwards compatibility. PreferPyIter_NextItem().Retorna el siguiente valor del iterador o. El objeto debe ser un iterador según
PyIter_Check()(depende del llamador verificar esto). Si no hay valores restantes, retornaNULLsin establecer una excepción. Si ocurre un error al recuperar el elemento, devuelveNULLy envía la excepción.
-
type PySendResult¶
El valor de enumeración utilizado para representar diferentes resultados de
PyIter_Send().Added in version 3.10.
-
PySendResult PyIter_Send(PyObject *iter, PyObject *arg, PyObject **presult)¶
- Part of the Stable ABI since version 3.10.
Envía el valor arg al iterador iter. Retorna:
PYGEN_RETURNsi el iterador regresa. El valor de retorno se retorna a través de presult.PYGEN_NEXTsi el iterador cede. El valor cedido se retorna a través de presult.PYGEN_ERRORsi el iterador ha lanzado una excepción. presult se establece enNULL.
Added in version 3.10.