Heim >Backend-Entwicklung >Python-Tutorial >Gibt der Bereich in Python3 einen Iterator zurück?

Gibt der Bereich in Python3 einen Iterator zurück?

爱喝马黛茶的安东尼
爱喝马黛茶的安东尼nach vorne
2019-06-03 15:31:133000Durchsuche

Was gibt die Reichweite von Pyhton3 zurück? Viele Leute werden ohne zu zögern sagen, dass dies nicht einfach ist. In Python 2 wird „range“ durch „xrange“ ersetzt und ein Iterator (Iterator) zurückgegeben.

Herzlichen Glückwunsch, Sie haben die Antwort falsch verstanden.

Gibt der Bereich in Python3 einen Iterator zurück?

range() gibt ein Iterable zurück, keinen Iterator.

a  Python 3.6.3 (default, Nov  3 2017, 14:41:25)
Type 'copyright', 'credits' or 'license' for more information
IPython 6.2.1 -- An enhanced Interactive Python. Type '?' for help.
In [1]: a = range(10) 
In [2]: a
Out[2]: range(0, 10)
In [3]: import collections
In [4]: isinstance(a, collections.Iterable)
Out[4]: True 
In [5]: isinstance(a, collections.Iterator)
Out[5]: False

Das Prinzip ist sehr einfach, lassen Sie uns kurz darüber sprechen Versuchen Sie zunächst nicht, die beiden Begriffe Iterable und Iterator zu vergleichen, da es sich um grundlegend unterschiedliche Konzepte handelt. Die wörtliche Bedeutung von beiden ist sehr klar: Iterable ist ein iterierbares Objekt, und der Aufruf von iter(Iterable) erhält einen Iterator, während Iterator ein Iterator ist und der Aufruf von next(Iterator) das nächste Element erhält.

Python respektiert Protokolle, was, um es ganz klar auszudrücken, Ententypisierung ist. Wenn Sie __iter__() implementieren (das heißt, Sie können einen Iterator erhalten, indem Sie iter() aufrufen), dann sind Sie ein Iterable; wenn Sie __next__() und __iter__() implementieren, sind Sie ein Iterator.

Moment mal, ruft Iterator nicht einfach next() auf, um das nächste Element abzurufen? Warum implementiert Iterator auch die __iter__()-Methode von Iterable?

Warum implementiert Pythons Iterator __iter__() (die übliche Implementierung ist return self). Die offizielle Dokumentation sagt es ganz klar.

Iterators are required to have an __iter__() method that returns the iterator object itself so every iterator is also iterable and may be used in most places where other iterables are accepted.

Eine einfache Übersetzung bedeutet, dass Iterator auch die Implementierung von __iter__() erfordert, da der an vielen Stellen empfangene Parameter ein Iterable ist. Wenn alle Iteratoren iterierbar sind, können diese Orte, die Iterable verwenden, ohne Hindernisse verwendet werden . Verwenden Sie Iterator. Nehmen wir zum Beispiel die for-Schleife. Ich habe diese Beschreibung im Python-Wiki gefunden (das ziemlich alt ist):

Basically, any object with an iterable method can be used in a for loop. Even strings, despite not having an iterable method – but we’ll not get on to that here.

Das heißt, die for-Schleife erhält einen iterierbaren Iterator und verwendet ihn dann Dieser Iterator führt Iterate durch. Wenn Iterator die Methode __iter__() implementiert, kann die for-Schleife ungehindert über Iterator iterieren. Ordentlich! Stellen Sie sich vor, dass der Generator von Python auch ein Iterator ist. Wenn die for-Schleife die Iterierung nicht unterstützen kann, wäre das Leben schlimmer als der Tod.

Es gibt also einen so „übermäßigen“ Bedarf an Iterator. Wir können denken, dass alle Iteratoren iterierbar sind. Zurück zur ursprünglichen Frage: Warum gibt range() ein Iterable anstelle eines Iterators zurück?

Angesichts der Tatsache, dass wir normalerweise range() verwenden, denken wir, dass es sich um einen Container handelt, der einen Bereich darstellt. Mit diesem Container können Sie problemlos andere Container initialisieren.

>>> numbers = range(3)
>>> tuple(numbers)
(0, 1, 2)
>>> tuple(numbers)
(0, 1, 2)

Wenn range() einen Iterator zurückgibt, dann ist der obige scheinbar normale Code in Schwierigkeiten:

>>> numbers = iter(range(3))
>>> tuple(numbers)
(0, 1, 2)
>>> tuple(numbers)
()

Zusammenfassung

Iterator ist zustandsbehaftet und kann nur einmal durchlaufen werden. Er ist „konsumierend“ und kann nicht „zweimal konsumiert“ werden. Iterable ist zustandslos (hier nicht zu streng, geschweige denn das Iterable von Iterator). Jedes Mal, wenn iter() für Iterable aufgerufen wird, wird ein neuer Iterator abgerufen.

Das obige ist der detaillierte Inhalt vonGibt der Bereich in Python3 einen Iterator zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:kawabangga.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen