Maison  >  Article  >  développement back-end  >  Les compréhensions de liste peuvent-elles avoir des itérateurs dépendants ?

Les compréhensions de liste peuvent-elles avoir des itérateurs dépendants ?

Barbara Streisand
Barbara Streisandoriginal
2024-11-02 13:21:02600parcourir

 Can List Comprehensions Have Dependent Iterators?

Itérateurs indépendants dans la compréhension de liste

En Python, les compréhensions de liste permettent plusieurs boucles d'itération. Considérons l'exemple suivant :

<code class="python">[(x, y) for x in a for y in b]</code>

où a et b sont des séquences. Cette compréhension crée des paires d'éléments à partir du produit cartésien de a et b.

Les itérateurs peuvent-ils être dépendants ?

Un itérateur dans une compréhension de liste peut-il faire référence à un autre ? La réponse est oui, et le code suivant le démontre :

<code class="python">[x for x in a for a in b]</code>

Dans cette compréhension, l'itérateur de boucle externe a devient l'itérateur de la boucle interne. Cela aplatit efficacement une liste imbriquée.

Exemple

Si nous avons une liste imbriquée a :

<code class="python">a = [[1, 2], [3, 4]]</code>

La compréhension de la liste suivante l'aplatirait en une seule liste :

<code class="python">[x for x in a for a in b]</code>

Résultat :

[1, 2, 3, 4]

Solution alternative utilisant des générateurs

Dans le code Python fourni, le texte est stockés sous forme de phrases, et la tâche consiste à extraire une seule liste de mots. Voici comment y parvenir à l'aide d'un générateur :

<code class="python">text = ((&quot;Hi&quot;, &quot;Steve!&quot;), (&quot;What's&quot;, &quot;up?&quot;))
gen = (word for sentence in text for word in sentence)</code>

La variable gen donne désormais la liste de mots aplatie :

<code class="python">for word in gen:
    print(word)</code>

Sortie :

Hi
Steve!
What's
up?

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn