이터레이터 객체¶
파이썬은 두 개의 범용 이터레이터 객체를 제공합니다. 첫째, 시퀀스 이터레이터는 __getitem__() 메서드를 지원하는 임의의 시퀀스와 작동합니다. 둘째는 콜러블 객체와 종료 신호(sentinel) 값을 사용하고, 시퀀스의 각 항목에 대해 콜러블을 호출하고, 종료 신호 값이 반환될 때 이터레이션을 종료합니다.
-
PyTypeObject PySeqIter_Type¶
- 상의 안정 ABI.
PySeqIter_New()와 내장 시퀀스 형에 대한iter()내장 함수의 단일 인자 형식에 의해 반환된 이터레이터 객체에 대한 형 객체.
-
int PySeqIter_Check(PyObject *op)¶
op의 형이
PySeqIter_Type이면 참을 돌려줍니다. 이 함수는 항상 성공합니다.
-
PyObject *PySeqIter_New(PyObject *seq)¶
- 반환값: 새 참조. 상의 안정 ABI.
일반 시퀀스 객체 seq와 함께 작동하는 이터레이터를 반환합니다. 시퀀스가 서브스크립션 연산에서
IndexError를 일으키면 이터레이션이 끝납니다.
-
PyTypeObject PyCallIter_Type¶
- 상의 안정 ABI.
PyCallIter_New()와iter()내장 함수의 두 인자 형식에 의해 반환된 이터레이터 객체에 대한 형 객체.
-
int PyCallIter_Check(PyObject *op)¶
op의 형이
PyCallIter_Type이면 참을 돌려줍니다. 이 함수는 항상 성공합니다.
-
PyObject *PyCallIter_New(PyObject *callable, PyObject *sentinel)¶
- 반환값: 새 참조. 상의 안정 ABI.
새로운 이터레이터를 돌려줍니다. 첫 번째 매개 변수 callable은 매개 변수 없이 호출할 수 있는 모든 파이썬 콜러블 객체일 수 있습니다; 각 호출은 이터레이션의 다음 항목을 반환해야 합니다. callable이 sentinel와 같은 값을 반환하면 이터레이션이 종료됩니다.
범위 객체¶
-
PyTypeObject PyRange_Type¶
- 상의 안정 ABI.
range객체를 위한 타입 객체입니다.
내장 이터레이터 형¶
이것들은 Python의 C API에 포함되어 있지만 추가 함수를 제공하지 않는 내장 이터레이션 유형입니다. 완전성을 위해 여기에 있습니다.
C 형식 |
파이썬 형 |
|---|---|
|
|
|
|
|
|
|
|
|
기타 이터레이터 객체¶
-
PyTypeObject PyByteArrayIter_Type¶
- 상의 안정 ABI.
-
PyTypeObject PyBytesIter_Type¶
- 상의 안정 ABI.
-
PyTypeObject PyListIter_Type¶
- 상의 안정 ABI.
-
PyTypeObject PyListRevIter_Type¶
- 상의 안정 ABI.
-
PyTypeObject PySetIter_Type¶
- 상의 안정 ABI.
-
PyTypeObject PyTupleIter_Type¶
- 상의 안정 ABI.
-
PyTypeObject PyRangeIter_Type¶
- 상의 안정 ABI.
-
PyTypeObject PyLongRangeIter_Type¶
- 상의 안정 ABI.
-
PyTypeObject PyDictIterKey_Type¶
- 상의 안정 ABI.
-
PyTypeObject PyDictRevIterKey_Type¶
- 상의 안정 ABI 버전 3.8 이후로.
-
PyTypeObject PyDictIterValue_Type¶
- 상의 안정 ABI.
-
PyTypeObject PyDictRevIterValue_Type¶
- 상의 안정 ABI 버전 3.8 이후로.
-
PyTypeObject PyDictIterItem_Type¶
- 상의 안정 ABI.
-
PyTypeObject PyDictRevIterItem_Type¶
- 상의 안정 ABI 버전 3.8 이후로.
-
PyTypeObject PyODictIter_Type¶
다양한 내장 객체의 이터레이터에 대한 유형 객체입니다.
직접 이러한 인스턴스를 생성하지 마십시오. 대신 :c:func:`PyObject_GetIter`를 호출하는 것이 좋습니다.
주어진 내장 타입이 특정 이터레이터 타입을 사용하는지 보장할 수 없습니다. 예를 들어, :class:`range`를 반복하면 range 크기에 따라 두 가지 이터레이터 타입 중 하나를 사용합니다. 다른 타입은 나중에 경고 없이 유사한 방식을 채택할 수 있습니다.