


Apprenez les méthodes magiques Python : une explication simple
Comprendre les méthodes magiques en Python
LesLes méthodes magiques en Python, également connues sous le nom de méthodes dunder (car elles ont des doubles traits de soulignement au début et à la fin de leur nom), nous permettent de définir le comportement de nos objets pour diverses opérations. Ils permettent un comportement personnalisé et peuvent faire en sorte que nos classes agissent comme des types intégrés. Dans ce blog, nous explorerons différentes catégories de méthodes magiques, fournirons des explications détaillées et donnerons des exemples pratiques et des cas d'utilisation.
1. Méthodes d'accès aux attributs
Ces méthodes magiques contrôlent la manière dont les attributs de vos objets sont consultés, modifiés ou supprimés.
__getattr__ et __getattribute__
__getattr__ : Appelé lorsqu'un attribut n'est pas trouvé dans un objet.
__getattribute__ : appelé sans condition pour accéder à n'importe quel attribut.
Exemple : accès aux attributs personnalisés avec journalisation
class LoggedAttributes: def __init__(self, name): self.name = name def __getattr__(self, item): print(f"Accessing non-existent attribute: {item}") return None def __getattribute__(self, item): print(f"Getting attribute: {item}") return super().__getattribute__(item) # Usage obj = LoggedAttributes("Alice") print(obj.name) # Output: Getting attribute: name\nAlice print(obj.age) # Output: Accessing non-existent attribute: age\nNone
Cas d'utilisation pratique : Journalisation de l'accès aux attributs dans un scénario de débogage pour tracer quand et comment les attributs sont accédés ou modifiés.
__setattr__ et __delattr__
__setattr__ : appelé lorsqu'une attribution d'attribut est tentée.
__delattr__ : appelé lorsqu'une suppression d'attribut est tentée.
Exemple : Modification d'attribut personnalisé avec validation
class Person: def __init__(self, name, age): self.name = name self.age = age def __setattr__(self, key, value): if key == "age" and value < 0: raise ValueError("Age cannot be negative") super().__setattr__(key, value) def __delattr__(self, item): if item == "name": raise AttributeError("Can't delete attribute 'name'") super().__delattr__(item) # Usage p = Person("Alice", 30) p.age = 25 # Works fine # p.age = -1 # Raises ValueError # del p.name # Raises AttributeError
Cas d'utilisation pratique : Application de règles ou de restrictions de validation lors de la définition ou de la suppression d'attributs.
2. Méthodes de conteneur
Ces méthodes magiques permettent à vos objets de se comporter comme des conteneurs (listes, dictionnaires, etc.).
__len__, __getitem__, __setitem__, __delitem__ et __iter__
__len__ : renvoie la longueur du conteneur.
__getitem__ : récupère un élément à un index ou une clé donnée.
__setitem__ : définit un élément à un index ou une clé donnée.
__delitem__ : supprime un élément à un index ou une clé donnée.
__iter__ : renvoie un objet itérateur.
Exemple : objet de type liste personnalisé
class CustomList: def __init__(self): self._items = [] def __len__(self): return len(self._items) def __getitem__(self, index): return self._items[index] def __setitem__(self, index, value): self._items[index] = value def __delitem__(self, index): del self._items[index] def __iter__(self): return iter(self._items) def append(self, item): self._items.append(item) # Usage cl = CustomList() cl.append(1) cl.append(2) cl.append(3) print(len(cl)) # Output: 3 print(cl[1]) # Output: 2 for item in cl: print(item) # Output: 1 2 3
Cas d'utilisation pratique : Création d'une classe de collection personnalisée qui nécessite un comportement spécialisé ou des méthodes supplémentaires tout en prenant en charge les opérations de liste standard.
3. Méthodes numériques et de comparaison
Ces méthodes définissent comment les objets de votre classe interagissent avec les opérations numériques et les comparaisons.
Méthodes numériques
- __add__, __sub__, __mul__, __truediv__, __floordiv__, __mod__, __pow__ : définissez les opérations arithmétiques.
Exemple : Classe de nombres complexes personnalisés
class Complex: def __init__(self, real, imag): self.real = real self.imag = imag def __add__(self, other): return Complex(self.real + other.real, self.imag + other.imag) def __sub__(self, other): return Complex(self.real - other.real, self.imag - other.imag) def __repr__(self): return f"({self.real} + {self.imag}i)" # Usage c1 = Complex(1, 2) c2 = Complex(3, 4) print(c1 + c2) # Output: (4 + 6i) print(c1 - c2) # Output: (-2 + -2i)
Cas d'utilisation pratique : Implémentation de types numériques personnalisés tels que des nombres complexes, des vecteurs ou des matrices.
Méthodes de comparaison
- __eq__, __ne__, __lt__, __le__, __gt__, __ge__ : définir les opérations de comparaison.
Exemple : implémentation du classement total pour une classe personnalisée
from functools import total_ordering @total_ordering class Book: def __init__(self, title, author): self.title = title self.author = author def __eq__(self, other): return (self.title, self.author) == (other.title, other.author) def __lt__(self, other): return (self.title, self.author) < (other.title, other.author) def __repr__(self): return f"{self.title} by {self.author}" # Usage book1 = Book("Title1", "Author1") book2 = Book("Title2", "Author2") books = [book2, book1] print(sorted(books)) # Output: [Title1 by Author1, Title2 by Author2]
Cas d'utilisation pratique : Permet de trier ou de comparer des objets personnalisés, utile dans les structures de données telles que les tas, les arbres de recherche binaires ou simplement lors du tri de listes d'objets personnalisés.
4. Méthodes de conteneurs : cas d'utilisation pratique
Dictionnaire personnalisé avec touches insensibles à la casse
Création d'un objet de type dictionnaire qui traite les clés comme insensibles à la casse.
Exemple : Dictionnaire insensible à la casse
class CaseInsensitiveDict: def __init__(self): self._data = {} def __getitem__(self, key): return self._data[key.lower()] def __setitem__(self, key, value): self._data[key.lower()] = value def __delitem__(self, key): del self._data[key.lower()] def __contains__(self, key): return key.lower() in self._data def keys(self): return self._data.keys() def items(self): return self._data.items() def values(self): return self._data.values() # Usage cid = CaseInsensitiveDict() cid["Name"] = "Alice" print(cid["name"]) # Output: Alice print("NAME" in cid) # Output: True
Cas d'utilisation pratique : Création de dictionnaires où les clés doivent être traitées comme insensibles à la casse, utiles pour gérer les entrées utilisateur, les paramètres de configuration, etc.
Conclusion
Les méthodes magiques offrent un moyen puissant de personnaliser le comportement de vos objets en Python. Comprendre et utiliser efficacement ces méthodes peut rendre vos classes plus intuitives et s'intégrer de manière transparente aux fonctions et opérateurs intégrés de Python. Que vous implémentiez des types numériques personnalisés, des conteneurs ou des modèles d'accès aux attributs, les méthodes magiques peuvent considérablement améliorer la flexibilité et les fonctionnalités de votre code
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

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.

Undress AI Tool
Images de déshabillage gratuites

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











Python est plus facile à apprendre et à utiliser, tandis que C est plus puissant mais complexe. 1. La syntaxe Python est concise et adaptée aux débutants. Le typage dynamique et la gestion automatique de la mémoire le rendent facile à utiliser, mais peuvent entraîner des erreurs d'exécution. 2.C fournit des fonctionnalités de contrôle de bas niveau et avancées, adaptées aux applications haute performance, mais a un seuil d'apprentissage élevé et nécessite une gestion manuelle de la mémoire et de la sécurité.

Est-ce suffisant pour apprendre Python pendant deux heures par jour? Cela dépend de vos objectifs et de vos méthodes d'apprentissage. 1) Élaborer un plan d'apprentissage clair, 2) Sélectionnez les ressources et méthodes d'apprentissage appropriées, 3) la pratique et l'examen et la consolidation de la pratique pratique et de l'examen et de la consolidation, et vous pouvez progressivement maîtriser les connaissances de base et les fonctions avancées de Python au cours de cette période.

Python est meilleur que C dans l'efficacité du développement, mais C est plus élevé dans les performances d'exécution. 1. La syntaxe concise de Python et les bibliothèques riches améliorent l'efficacité du développement. Les caractéristiques de type compilation et le contrôle du matériel de CC améliorent les performances d'exécution. Lorsque vous faites un choix, vous devez peser la vitesse de développement et l'efficacité de l'exécution en fonction des besoins du projet.

Python et C ont chacun leurs propres avantages, et le choix doit être basé sur les exigences du projet. 1) Python convient au développement rapide et au traitement des données en raison de sa syntaxe concise et de son typage dynamique. 2) C convient à des performances élevées et à une programmation système en raison de son typage statique et de sa gestion de la mémoire manuelle.

PythonlistSaReparmentofthestandardLibrary, tandis que les coloccules de colocède, tandis que les colocculations pour la base de la Parlementaire, des coloments de forage polyvalent, tandis que la fonctionnalité de la fonctionnalité nettement adressée.

Python excelle dans l'automatisation, les scripts et la gestion des tâches. 1) Automatisation: La sauvegarde du fichier est réalisée via des bibliothèques standard telles que le système d'exploitation et la fermeture. 2) Écriture de script: utilisez la bibliothèque PSUTIL pour surveiller les ressources système. 3) Gestion des tâches: utilisez la bibliothèque de planification pour planifier les tâches. La facilité d'utilisation de Python et la prise en charge de la bibliothèque riche en font l'outil préféré dans ces domaines.

Les applications de Python en informatique scientifique comprennent l'analyse des données, l'apprentissage automatique, la simulation numérique et la visualisation. 1.Numpy fournit des tableaux multidimensionnels et des fonctions mathématiques efficaces. 2. Scipy étend la fonctionnalité Numpy et fournit des outils d'optimisation et d'algèbre linéaire. 3. Pandas est utilisé pour le traitement et l'analyse des données. 4.Matplotlib est utilisé pour générer divers graphiques et résultats visuels.

Les applications clés de Python dans le développement Web incluent l'utilisation des cadres Django et Flask, le développement de l'API, l'analyse et la visualisation des données, l'apprentissage automatique et l'IA et l'optimisation des performances. 1. Framework Django et Flask: Django convient au développement rapide d'applications complexes, et Flask convient aux projets petits ou hautement personnalisés. 2. Développement de l'API: Utilisez Flask ou DjangorestFramework pour construire RestulAPI. 3. Analyse et visualisation des données: utilisez Python pour traiter les données et les afficher via l'interface Web. 4. Apprentissage automatique et AI: Python est utilisé pour créer des applications Web intelligentes. 5. Optimisation des performances: optimisée par la programmation, la mise en cache et le code asynchrones
