mirror of
https://github.com/python/cpython.git
synced 2025-12-08 06:10:17 +00:00
121 lines
3.7 KiB
ReStructuredText
121 lines
3.7 KiB
ReStructuredText
.. highlight:: c
|
|
|
|
.. _iterator-objects:
|
|
|
|
Iterator Objects
|
|
----------------
|
|
|
|
Python provides two general-purpose iterator objects. The first, a sequence
|
|
iterator, works with an arbitrary sequence supporting the :meth:`~object.__getitem__`
|
|
method. The second works with a callable object and a sentinel value, calling
|
|
the callable for each item in the sequence, and ending the iteration when the
|
|
sentinel value is returned.
|
|
|
|
|
|
.. c:var:: PyTypeObject PySeqIter_Type
|
|
|
|
Type object for iterator objects returned by :c:func:`PySeqIter_New` and the
|
|
one-argument form of the :func:`iter` built-in function for built-in sequence
|
|
types.
|
|
|
|
|
|
.. c:function:: int PySeqIter_Check(PyObject *op)
|
|
|
|
Return true if the type of *op* is :c:data:`PySeqIter_Type`. This function
|
|
always succeeds.
|
|
|
|
|
|
.. c:function:: PyObject* PySeqIter_New(PyObject *seq)
|
|
|
|
Return an iterator that works with a general sequence object, *seq*. The
|
|
iteration ends when the sequence raises :exc:`IndexError` for the subscripting
|
|
operation.
|
|
|
|
|
|
.. c:var:: PyTypeObject PyCallIter_Type
|
|
|
|
Type object for iterator objects returned by :c:func:`PyCallIter_New` and the
|
|
two-argument form of the :func:`iter` built-in function.
|
|
|
|
|
|
.. c:function:: int PyCallIter_Check(PyObject *op)
|
|
|
|
Return true if the type of *op* is :c:data:`PyCallIter_Type`. This
|
|
function always succeeds.
|
|
|
|
|
|
.. c:function:: PyObject* PyCallIter_New(PyObject *callable, PyObject *sentinel)
|
|
|
|
Return a new iterator. The first parameter, *callable*, can be any Python
|
|
callable object that can be called with no parameters; each call to it should
|
|
return the next item in the iteration. When *callable* returns a value equal to
|
|
*sentinel*, the iteration will be terminated.
|
|
|
|
|
|
Range Objects
|
|
^^^^^^^^^^^^^
|
|
|
|
.. c:var:: PyTypeObject PyRange_Type
|
|
|
|
The type object for :class:`range` objects.
|
|
|
|
|
|
.. c:function:: int PyRange_Check(PyObject *o)
|
|
|
|
Return true if the object *o* is an instance of a :class:`range` object.
|
|
This function always succeeds.
|
|
|
|
|
|
Builtin Iterator Types
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
These are built-in iteration types that are included in Python's C API, but
|
|
provide no additional functions. They are here for completeness.
|
|
|
|
|
|
.. list-table::
|
|
:widths: auto
|
|
:header-rows: 1
|
|
|
|
* * C type
|
|
* Python type
|
|
* * .. c:var:: PyTypeObject PyEnum_Type
|
|
* :py:class:`enumerate`
|
|
* * .. c:var:: PyTypeObject PyFilter_Type
|
|
* :py:class:`filter`
|
|
* * .. c:var:: PyTypeObject PyMap_Type
|
|
* :py:class:`map`
|
|
* * .. c:var:: PyTypeObject PyReversed_Type
|
|
* :py:class:`reversed`
|
|
* * .. c:var:: PyTypeObject PyZip_Type
|
|
* :py:class:`zip`
|
|
|
|
|
|
Other Iterator Objects
|
|
^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
.. c:var:: PyTypeObject PyByteArrayIter_Type
|
|
.. c:var:: PyTypeObject PyBytesIter_Type
|
|
.. c:var:: PyTypeObject PyListIter_Type
|
|
.. c:var:: PyTypeObject PyListRevIter_Type
|
|
.. c:var:: PyTypeObject PySetIter_Type
|
|
.. c:var:: PyTypeObject PyTupleIter_Type
|
|
.. c:var:: PyTypeObject PyRangeIter_Type
|
|
.. c:var:: PyTypeObject PyLongRangeIter_Type
|
|
.. c:var:: PyTypeObject PyDictIterKey_Type
|
|
.. c:var:: PyTypeObject PyDictRevIterKey_Type
|
|
.. c:var:: PyTypeObject PyDictIterValue_Type
|
|
.. c:var:: PyTypeObject PyDictRevIterValue_Type
|
|
.. c:var:: PyTypeObject PyDictIterItem_Type
|
|
.. c:var:: PyTypeObject PyDictRevIterItem_Type
|
|
.. c:var:: PyTypeObject PyODictIter_Type
|
|
|
|
Type objects for iterators of various built-in objects.
|
|
|
|
Do not create instances of these directly; prefer calling
|
|
:c:func:`PyObject_GetIter` instead.
|
|
|
|
Note that there is no guarantee that a given built-in type uses a given iterator
|
|
type. For example, iterating over :class:`range` will use one of two iterator
|
|
types depending on the size of the range. Other types may start using a
|
|
similar scheme in the future, without warning.
|