


Für Schleifen und Verständnis in Elixir – Imperativcode transformieren
In diesem Artikel behandeln wir einige häufige Verwendungen von For-Schleifen und Comprehensions in Python, wie man eine vorhandene Schleife analysiert und wie man sie in Elixir in die entsprechenden Ausdrücke umwandelt. Verwendung der Funktionen im Modul Enum und comprehensions.
Wir konzentrieren uns auf:
- Umwandeln einer Datensammlung durch eine Funktion (Karte)
- Werte in oder aus einer Sammlung filtern (Filter)
- Erzeugen eines einzelnen Aggregatwerts oder einer einzelnen Struktur, z. B. eines Durchschnitts (reduzieren oder falten)
Wir schließen mit einem einfachen Beispiel ab, das alle drei kombiniert!
Python
Für Schleifen
In Python verfügen for-Schleifen typischerweise über eine verschachtelte Verarbeitung – die Schritte werden in derselben Klausel oder demselben Textkörper zusammengefasst. Hier ist ein Beispiel, das die ersten beiden geraden Zahlen quadriert:
result = 0 for num in [1, 2, 3, 4, 5]: if num % 2 == 0: result += num ** 2 print(result) # Output: 20
Eine Herausforderung dieses verschachtelten Körpers besteht darin:
- Identifizieren Sie jeden Schritt und...
- Finden Sie heraus, um welche Art von Schritt es sich handelt.
Wenn Sie jeden Schritt aufschlüsseln, können Sie die stattfindenden Transformationen verstehen, unnötige eliminieren und diese Schritte in ein anderes Sprachkonstrukt oder eine Funktion auf höherer Ebene umschreiben.
Das Kommentieren der obigen Funktion führt zu:
result = 0 for num in [1, 2, 3, 4, 5]: ## Filter if num % 2 == 0: ## Reduce (result += ) and Map (num ** 2) result += num ** 2 print(result) # Output: 20
Die Schritte
Als Ergebnis lautet die Reihenfolge der Schritte:
- Filtern „out“ ungerade Zahlen/„in“ gerade Zahlen
- OrdnenZahlen (z. B. 2) der entsprechenden Quadratzahl (z. B. 4) zu
- Reduzierenauf eine Summe der quadrierten geraden Zahlen
Verständnis
Comprehensions in Python sind einfache Möglichkeiten, Sammlungen wie Listen und Wörterbücher zuzuordnen und zu filtern. Sie bieten keine Möglichkeit, das Ergebnis zu reduzieren, aber wir können integrierte Funktionen wie sum verwenden, um das Obige umzuwandeln und das Ergebnis des Verständnisses zu verarbeiten:
result = sum(num ** 2 for num in [1, 2, 3, 4, 5] if num % 2 == 0) print(result) # Output: 20
Mit Verständnis unterteilt der Ausdruck den Schritt Karte (Anzahl ** 2) und den Schritt Filter (bei Anzahl % 2). == 0) deutlich. Summe ist hier der Schritt Reduzieren.
Es ist einfach, diese Verständnisausdrücke in Python zu überfliegen, und es setzt eine sinnvolle Obergrenze für die Komplexität eines Verständnisses.
Mit diesem Hintergrund und einem besseren Verständnis der Struktur und Einschränkungen der Verarbeitungskonstrukte von Python fahren wir mit dem Umschreiben des obigen Python-Codes unter Verwendung der Verständnis- und Enum-Pipelines von Elixir fort!
Zuordnung: Enum.map und Generatoren
Wie können wir den Schritt zu Quadratzahlen schreiben? Bei Elixir ist es ganz einfach!
Verwenden von Enum.map:
result = 0 for num in [1, 2, 3, 4, 5]: if num % 2 == 0: result += num ** 2 print(result) # Output: 20
und Verständnis verwenden (für):
result = 0 for num in [1, 2, 3, 4, 5]: ## Filter if num % 2 == 0: ## Reduce (result += ) and Map (num ** 2) result += num ** 2 print(result) # Output: 20
Das <- stellt einen Generator-Ausdruck dar, der Werte generiert, die nach do:
im Hauptteil des for-Ausdrucks verwendet werdenFilterung: Enum.filter und Filter
Einfach mit Enum.filter (oder Enum.reject) zu machen:
result = sum(num ** 2 for num in [1, 2, 3, 4, 5] if num % 2 == 0) print(result) # Output: 20
Wir möchten ungerade Zahlen herausfiltern, bevor sie quadriert werden, also platzieren wir sie an der richtigen Stelle in der Pipeline – vor Enum.map.
Mithilfe von Verständnissen können wir dem Kopf des Verständnisses einen zweiten Ausdruck hinzufügen, einen Filter, der ein boolescher Test ist:
Enum.map([1, 2, 3, 4, 5], & &1 ** 2)
Der Ausdruck rem(n, 2) == 0 verwirft dann alle Elemente, die falsch (oder null) zurückgeben, und lässt [2, 4] als die Zahlen zurück, die tatsächlich an den Körper übergeben werden (do: n ** 2) des Verständnisses.
Reduzieren -> Enum.reduce und reduzieren:
Mit Enum.reduce/2 können wir eine Liste quadrierter Zahlen in ihre Summe umwandeln, indem wir sie zu einem Akkumulator addieren. Das erste Element wird als Anfangswert des Akkumulators verwendet, wenn wir keinen Anfangswert für den Akkumulator angeben (Enum.reduce/3), und das ist hier praktisch:
for n <- [1, 2, 3, 4, 5], do: n ** 2
Mit Comprehensions haben wir sogar noch mehr Leistung als das Python-Äquivalent. Wir können einen Reduzierungsschritt hinzufügen, indem wir dem Kopf eine weitere Klausel hinzufügen:
[1, 2, 3, 4, 5] |> Enum.filter(& rem(&1, 2) == 0) |> Enum.map(& &1 ** 2)
hier zwei Änderungen vornehmen:
- Hinzufügen einer Reduce: 0-Klausel zum Kopf, um anzugeben, dass wir einen Wert akkumulieren, dessen Anfangswert 0 ist
- Ändern des for-Körpers, um einen Acc-Wert (den Akkumulator) zu erfassen, zu dem wir den aktuellen quadrierten Wert addieren können.
Integrierte Funktionen: Enum.sum
Als allgemeine Regel sollten wir die Daten, die wir transformieren möchten, auf der höchstmöglichen Ebene ausdrücken. Es ist nützlich, sich Enum.reduce als die funktionale Transformation der niedrigsten Ebene vorzustellen, da alle anderen Datenverarbeitungsvorgänge in dieser Hinsicht neu geschrieben werden können.
Das Enum-Modul enthält viele übergeordnete Funktionen, die typischerweise das Reduzieren einer Liste von Werten auf einen einzigen Aggregatwert, wie eine Summe, ein Maximum oder ein Minimum, beinhalten. In diesem Fall möchten wir die Summe der Elemente.
Für Enum-Pipelines ist dies unkompliziert:
for n <- [1, 2, 3, 4, 5], rem(n, 2) == 0, do: n ** 2
Es gibt keine Möglichkeit, diese Aggregatfunktionen auf hoher Ebene in Comprehensions darzustellen, daher können wir die Ausgabe des Comprehensions wie folgt in einen Enum.sum-Aufruf weiterleiten, ähnlich wie wir es in Python gemacht haben:
[1, 2, 3, 4, 5] |> Enum.filter(& rem(&1, 2) == 0) |> Enum.map(& &1 ** 2) |> Enum.reduce(& &1 + &2)
Das Mischen verschiedener Formen sollte generell vermieden werden, insbesondere wenn es sich um eine einfache Transformation handelt, da dies zu einer geringeren mentalen Belastung für den Leser führt – die obenstehende Reduce:-Form ist tatsächlich klarer zu lesen, obwohl sie auf einem niedrigeren Niveau liegt.
Welcher Elixir-Ausdruck ist besser?
Zusammenfassend haben wir am Ende zwei Formen gefunden, die man als idiomatisch bezeichnen könnte. Für Enum-Pipelines:
result = 0 for num in [1, 2, 3, 4, 5]: if num % 2 == 0: result += num ** 2 print(result) # Output: 20
und Verständnis:
result = 0 for num in [1, 2, 3, 4, 5]: ## Filter if num % 2 == 0: ## Reduce (result += ) and Map (num ** 2) result += num ** 2 print(result) # Output: 20
Leicht lesbarer Code sollte einfach zu durchsuchen sein, ohne Unklarheiten oder Stolpern über Ausdrücke. Ich denke, dass beide Formen dieses Kriterium erfüllen, als:
- Sie folgen einer einzigen konsistenten Form – entweder Enum-Pipelines oder Comprehensions
- Jeder Ausdruck entspricht einem einzelnen Verarbeitungsschritt
- Es kann ohne Unterbrechung von oben nach unten oder von links nach rechts gelesen werden
Abschluss
Das Schreiben dieser Transformationen kann in Elixir auf verschiedene Arten erfolgen, und es ist für eine Codebasis leicht, Stile zu variieren, insbesondere wenn Code geändert wird und die Verarbeitung mit der Zeit komplizierter wird.
PureType kann Enum-Pipelines und -Verständnisse aufschlüsseln und analysieren, um sie in ihrer klarsten und idiomatischsten Form darzustellen, Ihre Vorlieben kennenzulernen und die Lesbarkeit und Klarheit Ihres Codes für andere im Team zu verbessern. Probieren Sie es noch heute aus!
Das obige ist der detaillierte Inhalt vonFür Schleifen und Verständnis in Elixir – Imperativcode transformieren. 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

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

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











Python eignet sich für Datenwissenschafts-, Webentwicklungs- und Automatisierungsaufgaben, während C für Systemprogrammierung, Spieleentwicklung und eingebettete Systeme geeignet ist. Python ist bekannt für seine Einfachheit und sein starkes Ökosystem, während C für seine hohen Leistung und die zugrunde liegenden Kontrollfunktionen bekannt ist.

Python zeichnet sich in Gaming und GUI -Entwicklung aus. 1) Spielentwicklung verwendet Pygame, die Zeichnungen, Audio- und andere Funktionen bereitstellt, die für die Erstellung von 2D -Spielen geeignet sind. 2) Die GUI -Entwicklung kann Tkinter oder Pyqt auswählen. Tkinter ist einfach und einfach zu bedienen. PYQT hat reichhaltige Funktionen und ist für die berufliche Entwicklung geeignet.

Sie können die Grundlagen von Python innerhalb von zwei Stunden lernen. 1. Lernen Sie Variablen und Datentypen, 2. Master -Steuerungsstrukturen wie wenn Aussagen und Schleifen, 3. Verstehen Sie die Definition und Verwendung von Funktionen. Diese werden Ihnen helfen, einfache Python -Programme zu schreiben.

Sie können grundlegende Programmierkonzepte und Fähigkeiten von Python innerhalb von 2 Stunden lernen. 1. Lernen Sie Variablen und Datentypen, 2. Master Control Flow (bedingte Anweisungen und Schleifen), 3.. Verstehen Sie die Definition und Verwendung von Funktionen, 4. Beginnen Sie schnell mit der Python -Programmierung durch einfache Beispiele und Code -Snippets.

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 wird in den Bereichen Webentwicklung, Datenwissenschaft, maschinelles Lernen, Automatisierung und Skripten häufig verwendet. 1) In der Webentwicklung vereinfachen Django und Flask Frameworks den Entwicklungsprozess. 2) In den Bereichen Datenwissenschaft und maschinelles Lernen bieten Numpy-, Pandas-, Scikit-Learn- und TensorFlow-Bibliotheken eine starke Unterstützung. 3) In Bezug auf Automatisierung und Skript ist Python für Aufgaben wie automatisiertes Test und Systemmanagement geeignet.

Um die Effizienz des Lernens von Python in einer begrenzten Zeit zu maximieren, können Sie Pythons DateTime-, Zeit- und Zeitplanmodule verwenden. 1. Das DateTime -Modul wird verwendet, um die Lernzeit aufzuzeichnen und zu planen. 2. Das Zeitmodul hilft, die Studie zu setzen und Zeit zu ruhen. 3. Das Zeitplanmodul arrangiert automatisch wöchentliche Lernaufgaben.

Python zeichnet sich in Automatisierung, Skript und Aufgabenverwaltung aus. 1) Automatisierung: Die Sicherungssicherung wird durch Standardbibliotheken wie OS und Shutil realisiert. 2) Skriptschreiben: Verwenden Sie die PSUTIL -Bibliothek, um die Systemressourcen zu überwachen. 3) Aufgabenverwaltung: Verwenden Sie die Zeitplanbibliothek, um Aufgaben zu planen. Die Benutzerfreundlichkeit von Python und die Unterstützung der reichhaltigen Bibliothek machen es zum bevorzugten Werkzeug in diesen Bereichen.
