Table des matières
Bonne réponse
Maison développement back-end Tutoriel Python Résultats étranges lors de la suppression d'éléments de la liste lors d'une itération sur la liste en Python

Résultats étranges lors de la suppression d'éléments de la liste lors d'une itération sur la liste en Python

Feb 09, 2024 am 10:10 AM
conversion implicite

在 Python 中迭代列表时从列表中删除项目时出现奇怪的结果

Contenu de la question

J'ai ce code :

numbers = list(range(1, 50))

for i in numbers:
    if i < 20:
        numbers.remove(i)

print(numbers)
Copier après la connexion

Cependant, le résultat que j'obtiens est :

[2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49]

Bien sûr, j'espère qu'il n'y aura pas de chiffres inférieurs à 20 dans les résultats. On dirait que j'ai fait quelque chose de mal lors de la suppression.


Bonne réponse


Vous modifiez la liste en l'itérant. Cela signifie qu'au premier passage dans la boucle, la valeur de i == 1,因此1被从列表中删除。然后for循环转到列表中的第二项,它不是2,而是3!然后将其从列表中删除,然后 for 循环继续执行列表中的第三项,现在是 5。依此类推。也许这样更容易可视化,用 ^ 指向 i est :

[1, 2, 3, 4, 5, 6...]
 ^
Copier après la connexion

C'est l'état initial de la liste ; puis 1 est supprimé et la boucle passe au deuxième élément de la liste :

[2, 3, 4, 5, 6...]
    ^
[2, 4, 5, 6...]
       ^
Copier après la connexion

Attendez.

Il n'existe pas de bon moyen de modifier la longueur d'une liste tout en la parcourant. La meilleure chose que vous puissiez faire est la suivante :

numbers = [n for n in numbers if n >= 20]
Copier après la connexion

Ou ceci, pour les changements sur place (l'élément entre parenthèses est une expression génératrice qui est implicitement convertie en tuple avant l'affectation de la tranche) :

numbers[:] = (n for n in numbers if n >= 20)
Copier après la connexion

Si vous souhaitez agir sur n avant de le supprimer, une astuce que vous pouvez essayer est la suivante :

for i, n in enumerate(numbers):
    if n < 20:
        print("do something")
        numbers[i] = None
numbers = [n for n in numbers if n is not None]
Copier après la connexion

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 de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser short en Java Comment utiliser short en Java May 07, 2024 am 03:33 AM

short est un type de données primitif en Java qui représente un entier signé de 16 bits compris entre -32 768 et 32 767. Il est souvent utilisé pour représenter de petits entiers, tels que des compteurs ou des identifiants, et prend en charge les opérations arithmétiques de base et les conversions de types. Mais comme short est un type signé, vous devez être prudent lorsque vous utilisez la division pour éviter tout débordement ou sous-dépassement.

Utilisation de ifnull dans SQL Utilisation de ifnull dans SQL Apr 28, 2024 am 09:57 AM

La fonction IFNULL vérifie si une expression est NULL et renvoie la valeur par défaut spécifiée si c'est le cas, sinon elle renvoie la valeur de l'expression. Il empêche les valeurs nulles de provoquer des erreurs, permet la manipulation des valeurs nulles et améliore la lisibilité des requêtes. L'utilisation comprend : le remplacement des valeurs nulles par des valeurs par défaut, l'exclusion des valeurs nulles des calculs et l'utilisation imbriquée pour gérer plusieurs situations de valeurs nulles.

Comment calculer la division en langage C Comment calculer la division en langage C Apr 13, 2024 pm 09:12 PM

En langage C, le comportement de l'opérateur de division / dépend du type de données des opérandes : Division entière : Lorsque l'opérande est un entier, une division entière est effectuée et le résultat est arrondi à l'inférieur. Division en virgule flottante : lorsque l'opérande est un nombre à virgule flottante, une division en virgule flottante est effectuée et le résultat est un nombre à virgule flottante. Conversion de type : lorsqu'un opérande est un entier et que l'autre ne l'est pas, l'entier est implicitement converti en nombre à virgule flottante, puis une division en virgule flottante est effectuée. Diviseur par 0 : Une erreur mathématique se produit lorsque le diviseur est 0. Fonctionnement modulo : utilisez l'opérateur % pour le fonctionnement modulo au lieu de la division modulo.

Que signifie char en Java ? Que signifie char en Java ? May 01, 2024 pm 06:15 PM

Le type char en Java est utilisé pour stocker un seul caractère Unicode, représentant 2 octets, allant de U+0000 à U+FFFF. Il est principalement utilisé pour stocker des caractères de texte. Il peut être initialisé via des guillemets simples ou des séquences d'échappement Unicode. et peuvent participer à la comparaison, les opérations d'égalité, d'inégalité et de jointure peuvent être implicitement converties en type int ou explicitement converties en objets Character.

Quelles sont les règles de correspondance pour la surcharge des fonctions C++ ? Quelles sont les règles de correspondance pour la surcharge des fonctions C++ ? Apr 27, 2024 am 08:27 AM

Les règles de correspondance de surcharge de fonctions C++ sont les suivantes : faire correspondre le nombre et le type de paramètres dans l'appel. L'ordre des paramètres doit être cohérent. Les modificateurs de constance et de référence doivent correspondre. Les paramètres par défaut peuvent être utilisés.

Que signifie * dans MySQL Que signifie * dans MySQL Apr 26, 2024 am 07:21 AM

L'astérisque (*) dans MySQL signifie « tout » et a différentes utilisations : Sélectionner toutes les colonnes Sélectionner toutes les lignes Caractères génériques JOIN pour la clause LIKE de table Quantificateur Conversion de type implicite pour la clause REGEXP

Utilisation de (+ dans Oracle Utilisation de (+ dans Oracle May 08, 2024 pm 08:12 PM

L'opérateur plus (+) dans Oracle peut être utilisé pour : connecter des chaînes, des nombres, des dates et des intervalles de temps ; gérer les valeurs NULL et convertir les valeurs NULL en valeurs non NULL ; convertir les types de données en types de chaîne.

Quels sont les types de paramètres de fonction PHP ? Quels sont les types de paramètres de fonction PHP ? Apr 10, 2024 pm 04:21 PM

Les types de paramètres de fonction PHP incluent les types scalaires (entiers, nombres à virgule flottante, chaînes, valeurs booléennes, valeurs nulles), les types composites (tableaux, objets) et les types spéciaux (fonctions de rappel, paramètres variables). Les fonctions peuvent convertir automatiquement des paramètres de différents types, mais elles peuvent également forcer des types spécifiques via des déclarations de type pour éviter les conversions accidentelles et garantir l'exactitude des paramètres.

See all articles