Was ist ein Python-Generator?
Ein Generator ist ein spezieller Iterator. Er verfügt auch intern über die Methoden __iter__
. Beim Beenden des Generators wird immer noch StopIteration
-Ausnahme, um die Schleife zu verlassen, aber im Vergleich zu Iteratoren verfügen Generatoren auch über die Funktion, „Zwischenwerte“ zu speichern und verwenden diesen „Zwischenwert“, wenn sie das nächste Mal ausgeführt werden. Das Schlüsselwort des Generators ist yield
. Schreiben wir unten den einfachsten Generator. __iter__
方法和__next__
方法,在终止生成器的时候,还是会抛StopIteration
异常以此来退出循环,只不过相比于迭代器,生成器还有特性会保存“中间值”,下次运行的时候,还会借助这个“中间值”来操作。生成器的关键字是yield
,我们下面来写一个最简单的生成器。
#!/usr/bin/env python def printNums(): i = 0 while i<10: yield i i = i + 1 def main(): for i in printNums(): print(i) if __name__ == '__main__': main()
粗看代码,可能会觉着这个是个啥啊,为啥不直接用range
来生成,偏偏要用yield
,哎,不急,我们接着往下看为什么需要生成器,或者说,生成器解决了什么问题。
为什么需要python生成器
在说明这个问题之前,我们先来写一个需求,输出 0——10000000 以内的数据,而后运行查看导出内存运行截图。
调用python程序内存信息辅助说明
这里可以借助python
的memory_profiler
模块来检测程序内存的占用情况。
安装memory_profiler
库:
pip3 install memory_profiler
使用方法很简单,在需要检测的函数或者是代码前添加@profile
装饰器即可,例如:
@profile def main(): pass
生成.dat
文件
mprof run
导出图示,可以使用
mprof plot --output=filename
python案例代码
以下2个程序,都是输出0—9999999之间的数据,不同的是,第一个程序是使用range
而后给append
进list
中,第二个则是使用迭代器来生成该数据。
main.py
程序
@profile def main(): data = list(range(10000000)) for i in data: pass if __name__ == '__main__': main()
main_2.py
程序
def printNum(): i = 0 while i < 10000000: yield i i = i + 1 @profile def main(): for i in printNum(): pass if __name__ == '__main__': main()
运行程序
代码也有了,就可以按照上述来运行一下程序,并且导出内存信息
运行后内存信息查看
main.py
运行内存图
main_2.py
运行内存图
如上2张对比图,当我们将数据叠加进列表,再输出的时候,占用内存接近400M,而使用迭代器来计算下一个值内存仅使用16M。
通过上述案例,我们应该知道为什么要使用生成器了吧。
python生成器原理
由于生成器表达式yield
语句涉及到了python
解释权内部机制,所以很难查看其源码,很难获取其原理,不过我们可以利用yield
的暂停机制,来探寻一下生成器。
可以编写如下代码:
def testGenerator(): print("进入生成器") yield "pdudo" print("第一次输出") yield "juejin" print("第二次输出") def main(): xx = testGenerator() print(next(xx)) print(next(xx)) if __name__ == '__main__': main()
运行后效果如下
通过上述实例,再结合下面这段生成器的运行过程,会加深对生成器的感触。
当python
遇到yield
语句时,会记录当前函数的运行状态,并且暂停执行,将结果抛出。会持续等待下一次调用__next__
方法,该方法调用后,会恢复函数的运行,直至下一个yield
语句或者函数结束,执行到最后没有yield
函数可执行的时候,会抛StopIteration
来标志生成器的结束。
生成器表达式
在python
中,生成器除了写在函数中,使用yield
返回之外,还可以直接使用生成器表达式,额。。。可能很抽象,但是你看下面这段代码,你就明白了。
def printNums(): for i in [1,2,3,4,5]: yield i def main(): for i in printNums(): print(i) gener = (i for i in [1,2,3,4,5]) for i in gener: print(i) if __name__ == '__main__': main()
其中,代码(i for i in [1,2,3,4,5])
就等同于printNums
函数,其类型都是生成器,我们可以使用type
rrreee
range
verwenden, um ihn zu generieren, sondern yield
, hey, keine Sorge, wir Schauen wir uns dann an, warum ein Generator benötigt wird, oder mit anderen Worten, welches Problem der Generator löst. Warum brauchen wir einen Python-Generator?Bevor wir dieses Problem erklären, schreiben wir zunächst eine Anforderung zur Ausgabe von Daten im Bereich von 0-10000000 und führen diese dann aus, um den Screenshot des exportierten Speichervorgangs anzuzeigen.
Hilfsanweisungen zum Aufrufen von Speicherinformationen für Python-Programme
🎜Hier können Sie das Modulmemory_profiler
von python
verwenden, um die Speichernutzung des Programms zu ermitteln. 🎜🎜Installieren Sie die memory_profiler
-Bibliothek: 🎜rrreee🎜Die Verwendung ist sehr einfach. Fügen Sie einfach den @profile
-Dekorator vor der Funktion oder dem Code hinzu, der erkannt werden muss, zum Beispiel: 🎜rrreee🎜 .dat
-Datei generieren 🎜🎜mprof run🎜Um das Diagramm zu exportieren, können Sie 🎜🎜
🎜mprof plot --output= verwenden Dateiname🎜
Python-Fallcode
🎜Die folgenden beiden Programme geben beide Daten zwischen 0 und 9999999 aus. Der Unterschied besteht darin, dass das erste Programmrange
verwendet und dann append
in list
, und der zweite verwendet einen Iterator, um die Daten zu generieren. 🎜🎜main.py
Program🎜rrreee🎜main_2.py
Program🎜rrreeeFühren Sie das Programm aus
🎜Jetzt, da Sie den Code haben, können Sie es ausführen Es wie oben beschrieben ausführen und Speicherinformationen exportieren Python" / >🎜Speicherinformationen nach dem Ausführen anzeigen
🎜main.py
Speicherdiagramm ausführen🎜🎜
main_2.py
Speicherdiagramm ausführen🎜🎜
yield
-Anweisung des Generatorausdrucks den internen Mechanismus der python
-Interpretationsleistung beinhaltet, ist es jedoch schwierig, ihren Quellcode anzuzeigen und ihr Prinzip zu erhalten können wir den Pausenmechanismus von yield
verwenden, um den Generator zu erkunden. 🎜🎜Sie können den folgenden Code schreiben: 🎜rrreee🎜Der Effekt nach dem Ausführen ist wie folgt🎜🎜
python
auf die yield
-Anweisung stößt, zeichnet es den Ausführungsstatus der aktuellen Funktion auf, unterbricht die Ausführung und gibt das Ergebnis aus. Es wartet weiterhin auf den nächsten Aufruf der Methode __next__
. Nach dem Aufruf dieser Methode wird die Funktion bis zur nächsten yield
-Anweisung oder bis zum Ende der Funktion weiter ausgeführt . Am Ende der Ausführung wird kein angezeigt. Wenn die Funktion yield
ausführbar ist, wird StopIteration
ausgelöst, um das Ende des Generators zu markieren. 🎜🎜Generatorausdruck🎜🎜In Python
können Sie nicht nur den Generator in eine Funktion schreiben und ihn mit yield
zurückgeben, sondern auch den Generatorausdruck direkt verwenden, ähm. . . Es mag abstrakt sein, aber wenn Sie sich den Code unten ansehen, werden Sie es verstehen. 🎜rrreee🎜Unter diesen entspricht der Code (i for i in [1,2,3,4,5])
der Funktion printNums
und seine Typen sind Generatoren können wir mit type
ausdrucken und einen Blick darauf werfen. 🎜🎜Ändern Sie den Code und das Ausgabeergebnis ist wie folgt:🎜🎜🎜🎜Das obige ist der detaillierte Inhalt vonWie funktionieren Generatoren in Python?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Python ist leichter zu lernen und zu verwenden, während C leistungsfähiger, aber komplexer ist. 1. Python -Syntax ist prägnant und für Anfänger geeignet. Durch die dynamische Tippen und die automatische Speicherverwaltung können Sie die Verwendung einfach zu verwenden, kann jedoch zur Laufzeitfehler führen. 2.C bietet Steuerung und erweiterte Funktionen auf niedrigem Niveau, geeignet für Hochleistungsanwendungen, hat jedoch einen hohen Lernschwellenwert und erfordert manuellem Speicher und Typensicherheitsmanagement.

Python und C haben signifikante Unterschiede in der Speicherverwaltung und -kontrolle. 1. Python verwendet die automatische Speicherverwaltung, basierend auf der Referenzzählung und der Müllsammlung, um die Arbeit von Programmierern zu vereinfachen. 2.C erfordert eine manuelle Speicherverwaltung und liefert mehr Kontrolle, aber die Komplexität und das Fehlerrisiko. Welche Sprache zu wählen sollte, sollte auf Projektanforderungen und Teamtechnologie -Stack basieren.

Zu den Anwendungen von Python im wissenschaftlichen Computer gehören Datenanalyse, maschinelles Lernen, numerische Simulation und Visualisierung. 1.Numpy bietet effiziente mehrdimensionale Arrays und mathematische Funktionen. 2. Scipy erweitert die Numpy -Funktionalität und bietet Optimierungs- und lineare Algebra -Tools. 3.. Pandas wird zur Datenverarbeitung und -analyse verwendet. 4.Matplotlib wird verwendet, um verschiedene Grafiken und visuelle Ergebnisse zu erzeugen.

Ob die Auswahl von Python oder C von den Projektanforderungen abhängt: 1) Python eignet sich aufgrund seiner prägnanten Syntax und reichhaltigen Bibliotheken für schnelle Entwicklung, Datenwissenschaft und Skripten; 2) C ist für Szenarien geeignet, die aufgrund seiner Zusammenstellung und des manuellen Speichermanagements eine hohe Leistung und die zugrunde liegende Kontrolle erfordern, wie z. B. Systemprogrammierung und Spielentwicklung.

Python wird in Datenwissenschaft und maschinellem Lernen häufig verwendet, wobei hauptsächlich auf seine Einfachheit und ein leistungsstarkes Bibliotheksökosystem beruhen. 1) Pandas wird zur Datenverarbeitung und -analyse verwendet, 2) Numpy liefert effiziente numerische Berechnungen, und 3) Scikit-Learn wird für die Konstruktion und Optimierung des maschinellen Lernens verwendet. Diese Bibliotheken machen Python zu einem idealen Werkzeug für Datenwissenschaft und maschinelles Lernen.

Ist es genug, um Python für zwei Stunden am Tag zu lernen? Es hängt von Ihren Zielen und Lernmethoden ab. 1) Entwickeln Sie einen klaren Lernplan, 2) Wählen Sie geeignete Lernressourcen und -methoden aus, 3) praktizieren und prüfen und konsolidieren Sie praktische Praxis und Überprüfung und konsolidieren Sie und Sie können die Grundkenntnisse und die erweiterten Funktionen von Python während dieser Zeit nach und nach beherrschen.

Zu den wichtigsten Anwendungen von Python in der Webentwicklung gehören die Verwendung von Django- und Flask -Frameworks, API -Entwicklung, Datenanalyse und Visualisierung, maschinelles Lernen und KI sowie Leistungsoptimierung. 1. Django und Flask Framework: Django eignet sich für die schnelle Entwicklung komplexer Anwendungen, und Flask eignet sich für kleine oder hochmobile Projekte. 2. API -Entwicklung: Verwenden Sie Flask oder Djangorestframework, um RESTFUFFUPI zu erstellen. 3. Datenanalyse und Visualisierung: Verwenden Sie Python, um Daten zu verarbeiten und über die Webschnittstelle anzuzeigen. 4. Maschinelles Lernen und KI: Python wird verwendet, um intelligente Webanwendungen zu erstellen. 5. Leistungsoptimierung: optimiert durch asynchrones Programmieren, Caching und Code

Python ist in der Entwicklungseffizienz besser als C, aber C ist in der Ausführungsleistung höher. 1. Pythons prägnante Syntax und reiche Bibliotheken verbessern die Entwicklungseffizienz. 2. Die Kompilierungsmerkmale von Compilation und die Hardwarekontrolle verbessern die Ausführungsleistung. Bei einer Auswahl müssen Sie die Entwicklungsgeschwindigkeit und die Ausführungseffizienz basierend auf den Projektanforderungen abwägen.


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

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung