Protocolo Iterador¶
Existem duas funções especificas para trabalhar com iteradores.
-
int PyIter_Check(PyObject *o)¶
- Parte da ABI Estável desde a versão 3.8.
Retorna valor diferente de zero se o objeto o puder ser passado com segurança para
PyIter_Next()
, e0
caso contrário. Esta função sempre é bem-sucedida.
-
int PyAIter_Check(PyObject *o)¶
- Parte da ABI Estável desde a versão 3.10.
Retorna valor diferente de zero se o objeto o fornecer o protocolo
AsyncIterator
e0
caso contrário. Esta função sempre é bem-sucedida.Adicionado na versão 3.10.
-
PyObject *PyIter_Next(PyObject *o)¶
- Retorna valor: Nova referência. Parte da ABI Estável.
Retorna o próximo valor do iterador o. O objeto deve ser um iterador de acordo com
PyIter_Check()
(cabe ao chamador verificar isso). Se não houver valores restantes, retornaNULL
sem nenhuma exceção definida. Se ocorrer um erro ao recuperar o item, retornaNULL
e passa a exceção.
Para escrever um laço que itere sobre um iterador, o código C deve ser algo como isto:
PyObject *iterator = PyObject_GetIter(obj);
PyObject *item;
if (iterator == NULL) {
/* propaga o erro */
}
while ((item = PyIter_Next(iterator))) {
/* faz algo com o item */
...
/* liberar a referência quando concluído */
Py_DECREF(item);
}
Py_DECREF(iterator);
if (PyErr_Occurred()) {
/* propaga o erro */
}
else {
/* continua fazendo algum trabalho útil */
}
-
type PySendResult¶
O valor de enum usado para representar diferentes resultados de
PyIter_Send()
.Adicionado na versão 3.10.
-
PySendResult PyIter_Send(PyObject *iter, PyObject *arg, PyObject **presult)¶
- Parte da ABI Estável desde a versão 3.10.
Envia o valor arg para o iterador iter. Retorna:
PYGEN_RETURN
se o iterador retornar. O valor de retorno é retornado via presult.PYGEN_NEXT
se o iterador render. O valor preduzido é retornado via presult.PYGEN_ERROR
se o iterador tiver levantado uma exceção. presult é definido comoNULL
.
Adicionado na versão 3.10.