Single Responsibility Principle(SRP)
Ce principe stipule que chaque classe doit avoir une seule responsabilité. Il souligne qu'une classe doit remplir une fonction spécifique et ne pas avoir trop de raisons de changer.
Exemple : Gestion des informations utilisateur et envoi de notifications par e-mail.
class UserManager:
def create_user(self, user_data):
# Logic for creating a user
pass
class EmailService:
def send_email(self, email_data):
# Logic for sending an email
pass
Open/Closed Principle(OCP)
Ce principe encourage l'extension des fonctionnalités en ajoutant du nouveau code plutôt qu'en modifiant le code existant.
Exemple: Gestion de différents modes de paiement dans une application e-commerce.
from abc import ABC, abstractmethod
class PaymentProcessor(ABC):
@abstractmethod
def process_payment(self):
pass
class CreditCardPaymentProcessor(PaymentProcessor):
def process_payment(self):
# Logic for processing credit card payment
pass
class PayPalPaymentProcessor(PaymentProcessor):
def process_payment(self):
# Logic for processing PayPal payment
pass
Liskov Substitution Principle(LSP)
Ce principe affirme que les objets d'une classe dérivée doivent être substituables aux objets de la classe de base sans affecter l'exactitude du programme.
Exemple: Gestion des formes géométriques.
class Shape:
def area(self):
pass
class Rectangle(Shape):
def area(self):
return self.width * self.height
class Square(Shape):
def area(self):
return self.side * self.side
Interface Segregation Principle(ISP)
Ce principe conseille de diviser les interfaces en plus petites afin d'éviter de forcer les classes à implémenter des méthodes dont elles n'ont pas besoin.
Exemple: Interfaces de mise à jour et d'affichage des données.
class UpdateableFeature:
@abstractmethod
def update_feature(self):
pass
class DisplayableFeature:
@abstractmethod
def display_feature(self):
pass
Dependency Inversion Principle(DIP)
Ce principe suggère d'utiliser l'injection de dépendances pour gérer les dépendances.
Exemple : Utilisation de l'injection de dépendances pour gérer les dépendances.
class OrderProcessor:
def __init__(self, db_connection, email_service):
self.db_connection = db_connection
self.email_service = email_service
N'oubliez pas que l'application SOLID des principes Python doit être faite avec souplesse en fonction de l'objectif spécifique de votre projet et de votre compréhension de SOLID et Python.