


Wie verwende ich Iteratoren und Listenverständnisse in Python?
Iterator: Eine vorläufige Studie
Wie im vorherigen Kapitel erwähnt, kann die for-Schleife tatsächlich für jedes iterierbare Objekt verwendet werden. Tatsächlich gilt dies für alle Iterationstools in Python, die Objekte von links nach rechts scannen, einschließlich For-Schleifen, Listenverständnissen, Mitgliedschaftstests und der integrierten Map-Funktion.
Das Konzept der „iterierbaren Objekte“ ist in Python recht neu. Im Grunde ist dies die Verallgemeinerung des Sequenzkonzepts: Wenn das Objekt eine tatsächlich gespeicherte Sequenz ist oder in der Iteration jeweils ein Ergebnis erzeugen kann Werkzeugumgebungsobjekt gilt als iterierbar.
>>File Iterator
Als integrierter Datentyp sind Dateien auch iterierbar. Es gibt eine Methode namens __next__, die bei jedem Aufruf zurückgegeben wird nächste Zeile in der Datei. Wenn das Ende der Datei erreicht ist, löst __next__ die integrierte StopIteration-Ausnahme aus, anstatt eine leere Zeichenfolge zurückzugeben.
Diese Schnittstelle ist das sogenannte Iterationsprotokoll in Python: Ein Objekt mit einer __next__-Methode wechselt zum nächsten Ergebnis, und am Ende einer Reihe von Ergebnissen wird StopIteration ausgelöst. Jedes dieser Objekte gilt als iterierbar. Jedes dieser Objekte kann auch mit einer for-Schleife oder einem anderen Iterationstool iteriert werden, da alle Iterationstools intern funktionieren, indem sie bei jeder Iteration __next__ aufrufen und die StopIteratin-Ausnahme abfangen, um zu bestimmen, wann sie verlassen werden sollen.
Python-Iteratoren und Listenanalyse
1) Iteratoren
一种特殊的数据结构,以对象形式存在 >>> i1 = l1.__iter__() >>> i1 = iter(l1) 可迭代对象: 序列: list、str、tuple 非序列: dict、file 自定义类: __iter__()、 __getitem__() 注意: 若要实现迭代器,需要在类中定义next()方法 要使迭代器指向下一个对象,则使用成员函数 next() i1.next() 当没有元素时,会引发StopIteration异常 for循环可用于任何可迭代对象 例: >>> l1 = ['Sun','Mon','Tue','Wed','Thu','Fri','Sat'] >>> i1 = l1.__iter__() >>> il.next() 'Sun' >>> il.next() 'Mon'
2) Listenanalyse [ ]
根据已有列表,高效生产新列表的方式。 常用于实现创建新的列表,因此要放置于 [ ] 中 语法: [ expression for iter_var in iterable ] [ expression for iter_var in iterable if cond_expr ] os模块中 listdir() 能够列出所有文件 例:事先定义l1 l2 l1 = [ 1,2,3,4,5 ] l2=[ ] >>> for i in l1: l2.append(i**2) l2列表内各项为l1的平方 >>> print l2 [1, 4, 9, 16, 25] >>> l3 = [ i**2 for i in l1 ] l3列表内各项为l1的平方 [1, 4, 9, 16, 25] >>> l4 = [ i**2 for i in l1 if i>=3 ] l3列表内各项为l1中 >= 3的平方 [9, 16, 25] 例题: l1 = ['x','y','z'] l2 = [1,2,3] 应用列表解析方法使其各项相乘 >>> l3 = [ (i,j) for i in l1 for j in l2 ] for循环内部嵌套一个for循环实现各项乘 [('x', 1), ('x', 2), ('x', 3), ('y', 1), ('y', 2), ('y', 3), ('z', 1), ('z', 2), ('z', 3)]
3) Generator ( )
惰性计算、延迟求值 生成器表达式并不真正创建数字列表,而是返回一个生成器对象,此对象在每次计算出一个条目后,把这个条目产生出来(一次返回一个值) 语法: ( expr for iter_var in iterable ) ( expr for iter_var in iterable if cond_expr ) 例: >>> l1 = ( i**2 for i in range(2,11,2)) >>> l1.next() 2 >>> l1 = ( i**2 for i in range(2,11) if i%2==0 ) >>> l1.next() 2 注意: 序列过长,并且每次只获取一个元素时,应当考虑使用生成器表达式而不是列表解析 列表解析与生成器的关系相当于range()与xrange()
4) Offset und Element generieren
enumerate 同时偏移缩印和偏移元素,使用enumerate()函数 此内置函数返回一个生成器对象 >>> S = 'Hello,world' >>> a = enumerate(S) >>> a.next() (0,'H') >>> a.next() (1,'e')
Das obige ist der detaillierte Inhalt vonWie verwende ich Iteratoren und Listenverständnisse in Python?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Viele Website -Entwickler stehen vor dem Problem der Integration von Node.js oder Python Services unter der Lampenarchitektur: Die vorhandene Lampe (Linux Apache MySQL PHP) Architekturwebsite benötigt ...

Bei der Verwendung von Scapy Crawler kann der Grund, warum Pipeline persistente Speicherdateien nicht geschrieben werden kann? Diskussion beim Lernen, Scapy Crawler für Data Crawler zu verwenden, begegnen Sie häufig auf eine ...

Python Process Pool verarbeitet gleichzeitige TCP -Anfragen, die dazu führen, dass der Client stecken bleibt. Bei der Verwendung von Python für die Netzwerkprogrammierung ist es entscheidend, gleichzeitige TCP -Anforderungen effizient zu verarbeiten. ...

Erforschen Sie tief die Betrachtungsmethode von Python Functools.Partialial Object in functools.Partial mit Python ...

Lösung für Erlaubnisprobleme beim Betrachten der Python -Version in Linux Terminal Wenn Sie versuchen, die Python -Version in Linux Terminal anzuzeigen, geben Sie Python ein ...

Auswahl der Python-plattformübergreifenden Desktop-Anwendungsentwicklungsbibliothek Viele Python-Entwickler möchten Desktop-Anwendungen entwickeln, die sowohl auf Windows- als auch auf Linux-Systemen ausgeführt werden können ...

Erste Schritte mit Python: Hourglas -Grafikzeichnung und Eingabeüberprüfung In diesem Artikel wird das Problem der Variablendefinition gelöst, das von einem Python -Anfänger im Hourglass -Grafikzeichnungsprogramm auftritt. Code...

Datenkonvertierung und Statistik: Effiziente Verarbeitung großer Datensätze In diesem Artikel werden ausführlich das Umwandeln einer Datenliste in eine andere enthält ...
