développement back-end
Tutoriel Python
Comment filtrer des éléments dans une séquence en Python
Comment filtrer des éléments dans une séquence en Python
Le contenu de cet article explique comment Python filtre les éléments dans une séquence. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.
1. Exigences
La séquence contient certaines données, nous devons extraire les valeurs ou supprimer la séquence selon certaines normes,
2. Solution
Pour filtrer les données dans une séquence, le moyen le plus simple est généralement d'utiliser une compréhension de liste.
Par exemple :
myList=[1,4,-5,10,-7,2,3,-1] print([n for n in myList if n>0]) print([n for n in myList if n<0])
Résultat :
[1, 4, 10, 2, 3] [-5, -7, -1]
Un inconvénient potentiel de l'utilisation des compréhensions de liste est que si l'entrée d'origine est très volumineuse, elle mai produira un résultat énorme. Si c'est quelque chose que vous devez prendre en compte, vous pouvez utiliser une expression génératrice pour produire des résultats filtrés de manière itérative, par exemple :
myList=[1,4,-5,10,-7,2,3,-1] pos=(n for n in myList if n >0) for x in pos: print(x)
Résultat :
1 4 10 2 3
Parfois, les critères filtrés ne peuvent pas être exprimés simplement dans des compréhensions de listes ou des expressions génératrices. Par exemple : supposons que le processus de filtrage implique la gestion des exceptions ou d’autres détails complexes. Sur cette base, vous pouvez placer le code qui gère la logique de filtrage dans une fonction distincte, puis utiliser la fonction filter() intégrée pour le traiter. L'exemple est le suivant :
values=['1','2','-3','-','4','N/A','5'] def is_int(val): try: x=int(val) return True except ValueError: return False ivals=list(filter(is_int,values)) print(ivals)
Résultat. :
['1', '2', '-3', '4', '5']
filter() crée un itérateur, donc si nous voulons le résultat sous forme de liste, assurez-vous d'inclure list(), comme dans l'exemple.
3. Analyse
Les compréhensions de listes et les expressions génératrices sont généralement le moyen le plus simple et le plus direct de filtrer les données. De plus, ils ont également la capacité de transformer les données simultanément. Par exemple :
import math myList=[1,4,-5,10,-7,2,3,-1] print([math.sqrt(n) for n in myList if n>0])
Résultat :
[1.0, 2.0, 3.1622776601683795, 1.4142135623730951, 1.7320508075688772]
Concernant le filtrage des données, une situation consiste à remplacer les valeurs qui ne répondent pas aux critères par de nouvelles valeurs au lieu de les supprimer. eux. Par exemple. En plus de rechercher des entiers positifs, nous souhaitons également remplacer les valeurs qui ne répondent pas aux exigences dans une plage spécifiée. Souvent, cela est facilement accompli en déplaçant le filtre dans une expression conditionnelle, comme ceci :
myList=[1,4,-5,10,-7,2,3,-1] print([n if n>0 else 0 for n in myList]) print([n if n<0 else 0 for n in myList])
Résultat :
[1, 4, 0, 10, 0, 2, 3, 0] [0, 0, -5, 0, -7, 0, 0, -1]
Un autre outil à mentionner. L'outil de filtre est itertools.compress() , qui accepte un itérable et une séquence de sélecteurs booléens en entrée. En sortie, il donne tous les éléments d'objet itérables qui sont True dans le sélecteur booléen correspondant. Ceci est utile si vous souhaitez appliquer les résultats d'un filtre sur une séquence à une autre séquence associée.
Par exemple :
from itertools import compress address=[ '5412 N CLARK1', '5148 N CLARK2', '5800 E CLARK3', '2122 N CLARK4', '5645 M CLARK5', '1060 W CLARK6', ] counts=[0,3,10,4,1,7] #构建一个列表,它相应的count值要大于5 more5=[n>5 for n in counts] print(more5) print(list(compress(address,more5)))
Résultat :
[False, False, True, False, False, True] ['5800 E CLARK3', '1060 W CLARK6']
La clé ici est de créer d'abord une séquence booléenne pour représenter quel élément satisfait nos conditions, puis Le La fonction compress() sélectionne les éléments correspondants dont la valeur booléenne est True.
Semblable à la fonction filter(), compress() renverra un itérateur dans des circonstances normales. Par conséquent, si nécessaire, vous devez utiliser list() pour convertir le résultat en liste.
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!
Outils d'IA chauds
Undress AI Tool
Images de déshabillage gratuites
Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes
AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.
Clothoff.io
Dissolvant de vêtements AI
Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !
Article chaud
Outils chauds
Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit
SublimeText3 version chinoise
Version chinoise, très simple à utiliser
Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP
Dreamweaver CS6
Outils de développement Web visuel
SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)
Sujets chauds
1793
16
1735
56
1585
29
267
587
Une classe Python peut-elle avoir plusieurs constructeurs?
Jul 15, 2025 am 02:54 AM
Oui, apythonclasscanhavemultipleconstructorshroughalterativetechniques.1.UseaultArgumentsInthe__Init__MethodtoallowflexibleInitializationwithVaryingNumbersofParameters.2.DefineclassMethodsAnterveConstructorForCeleArandScalableableBjectCraturé
Python pour la gamme de boucle
Jul 14, 2025 am 02:47 AM
Dans Python, l'utilisation d'une boucle pour la fonction avec la plage () est un moyen courant de contrôler le nombre de boucles. 1. Utilisez lorsque vous connaissez le nombre de boucles ou avez besoin d'accès aux éléments par index; 2. Plage (arrêt) de 0 à l'arrêt-1, plage (démarrage, arrêt) du début à l'arrêt-1, plage (démarrage, arrêt) ajoute la taille de l'étape; 3. Notez que la plage ne contient pas la valeur finale et renvoie des objets itérables au lieu de listes dans Python 3; 4. Vous pouvez vous convertir en liste via la liste (plage ()) et utiliser la taille de pas négative dans l'ordre inverse.
Accéder aux données à partir d'une API Web dans Python
Jul 16, 2025 am 04:52 AM
La clé de l'utilisation de Python pour appeler WebAPI pour obtenir des données est de maîtriser les processus de base et les outils communs. 1. L'utilisation des demandes pour lancer des demandes HTTP est le moyen le plus direct. Utilisez la méthode GET pour obtenir la réponse et utilisez JSON () pour analyser les données; 2. Pour les API qui nécessitent une authentification, vous pouvez ajouter des jetons ou des clés via des en-têtes; 3. Vous devez vérifier le code d'état de réponse, il est recommandé d'utiliser Response.RAISE_FOR_STATUS () pour gérer automatiquement les exceptions; 4. Face à l'interface de pagination, vous pouvez demander différentes pages et ajouter des retards pour éviter les limitations de fréquence; 5. Lors du traitement des données JSON renvoyées, vous devez extraire des informations en fonction de la structure et les données complexes peuvent être converties en données
python une ligne si d'autre
Jul 15, 2025 am 01:38 AM
Python's Onelineifelse est un opérateur ternaire, écrit comme XifConditionelSey, qui est utilisé pour simplifier le jugement conditionnel simple. Il peut être utilisé pour une affectation variable, tel que status = "adulte" ifage> = 18Else "mineur"; Il peut également être utilisé pour renvoyer directement les résultats dans des fonctions, telles que Deget_Status (âge): renvoyer "adulte" ifage> = 18else "mineur"; Bien que l'utilisation imbriquée soit prise en charge, comme le résultat = "A" i
Comment lire un fichier JSON dans Python?
Jul 14, 2025 am 02:42 AM
La lecture des fichiers JSON peut être implémentée dans Python via le module JSON. Les étapes spécifiques sont les suivantes: utilisez la fonction Open () pour ouvrir le fichier, utilisez json.load () pour charger le contenu, et les données seront renvoyées dans un formulaire de dictionnaire ou de liste; Si vous traitez les chaînes JSON, vous devez utiliser JSON.loads (). Les problèmes communs incluent les erreurs de chemin de fichier, le format JSON incorrect, les problèmes de codage et les différences de conversion du type de données. Faites attention à la précision du chemin, à la légalité du format, aux paramètres d'encodage et à la cartographie des valeurs booléennes et null.
Python pour Loop pour lire la file ligne par ligne
Jul 14, 2025 am 02:47 AM
L'utilisation d'une boucle pour lire les fichiers ligne par ligne est un moyen efficace de traiter les fichiers volumineux. 1. L'utilisation de base consiste à ouvrir le fichier via Openn () et à gérer automatiquement la fermeture. Combiné avec ForLineInfile pour traverser chaque ligne. line.strip () peut supprimer les ruptures de ligne et les espaces; 2. Si vous avez besoin d'enregistrer le numéro de ligne, vous pouvez utiliser l'énumération (fichier, start = 1) pour permettre au numéro de ligne de démarrer à partir de 1; 3. Lors du traitement des fichiers non ASCII, vous devez spécifier des paramètres d'encodage tels que UTF-8 pour éviter les erreurs de codage. Ces méthodes sont concises et pratiques, et conviennent à la plupart des scénarios de traitement de texte.
chaîne de cas de cas Python Comparez si
Jul 14, 2025 am 02:53 AM
Le moyen le plus direct de faire des comparaisons de chaînes insensibles à des cas dans Python est d'utiliser .Lower () ou .upper () à comparer. Par exemple: str1.lower () == str2.lower () peut déterminer s'il est égal; Deuxièmement, pour le texte multilingue, il est recommandé d'utiliser une méthode Casefold () plus approfondie, telle que "Straß" .Casefold () sera converti en "strasse", tandis que .Lower () peut conserver des caractères spécifiques; De plus, il doit être évité d'utiliser directement == Comparaison directement, à moins que le cas ne soit confirmé comme cohérent, il est facile de provoquer des erreurs logiques; Enfin, lors du traitement de la saisie, de la base de données ou de la correspondance des utilisateurs
Comment utiliser la fonction de carte dans Python
Jul 15, 2025 am 02:52 AM
La fonction MAP () de Python implémente une conversion de données efficace en agissant comme fonctions spécifiées sur chaque élément de l'objet itérable à son tour. 1. Son utilisation de base est la carte (fonction, itérable), qui renvoie un objet MAP "Loot Lazy", qui est souvent converti en List () pour afficher les résultats; 2. Il est souvent utilisé avec Lambda, qui convient à une logique simple, comme la conversion des chaînes en majuscules; 3. Il peut être transmis dans plusieurs objets itérables, à condition que le nombre de paramètres de fonction correspond, tels que le calcul du prix actualisé et de la remise; 4. Les techniques d'utilisation comprennent la combinaison de fonctions intégrées pour taper rapidement la conversion, la gestion des situations similaires à Zip () et d'éviter la nidification excessive pour affecter la lisibilité. Masterring Map () peut rendre le code plus concis et professionnel


