Unabhängige Iteratoren im Listenverständnis
In Python ermöglichen Listenverständnisse mehrere Iterationsschleifen. Betrachten Sie das folgende Beispiel:
[(x, y) for x in a for y in b]
wobei a und b Folgen sind. Dieses Verständnis erzeugt Paare von Elementen aus dem kartesischen Produkt von a und b.
Können Iteratoren abhängig sein?
Kann ein Iterator in einem Listenverständnis auf einen anderen verweisen? Die Antwort lautet „Ja“, und der folgende Code demonstriert dies:
[x for x in a for a in b]
In diesem Verständnis wird der Iterator der äußeren Schleife a zum Iterator für die innere Schleife. Dies reduziert effektiv eine verschachtelte Liste.
Beispiel
Wenn wir eine verschachtelte Liste a haben:
a = [[1, 2], [3, 4]]
Das folgende Listenverständnis würde es zu einer einzigen zusammenfassen Liste:
[x for x in a for a in b]
Ergebnis:
[1, 2, 3, 4]
Alternative Lösung mit Generatoren
Im bereitgestellten Python-Code wird der Text als Sätze gespeichert, und die Aufgabe ist um eine einzelne Liste von Wörtern zu extrahieren. So können Sie dies mit einem Generator erreichen:
text = (("Hi", "Steve!"), ("What's", "up?"))
gen = (word for sentence in text for word in sentence)
Die Gen-Variable liefert nun die abgeflachte Liste von Wörtern:
for word in gen:
print(word)
Ausgabe:
Hi Steve! What's up?
Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3