Les méthodes de classes sont différentes des méthodes d’instances en ce qu’elles prennent comme premier argument la classe elle-même. De plus, une méthode de classe est liée à la classe, mais pas à l’objet de cette classe.

méthodes de classes et statiques

Nous avons déjà vu la méthode d’instance qui prend en paramètre self , qui pointe vers l’instance de l’objet qui a appelé la méthode.

Cependant, une méthode de classe est une méthode qui a accès à l’état de la classe. Pour la créer, on utilise le décorateur @classmethod.

Si vous ne savez pas ce qu’un décorateur, voici un article qui vous expliquera pas à pas ce concept.

@classmethod 
def fonction(cls, param1, param2,.... , paramN): 
  # la fonction

Avant de continuer, nous allons aborder une autre forme de méthodes. Ce sont les méthodes statiques, qui ne prennent pas d’instance d’objet (self) ou de classe (cls), ce qui signifie qu’elles ne peuvent pas accéder à leurs états. Mais elles sont liées à la classe.
Le décorateur @staticmethod est utilisé pour créer une méthode statique.

Les méthodes d’instances, de classes et statiques

Nous allons prendre un exemple simple pour vous permettre de faire la différence entre ces trois formes de méthodes.

class Calcul:
  num1 = 10                     #attribut de classe
  def __init__(self, num2):
    self.num2 = num2            #attribut d'instance

  def mtd_instance(self, num3):
    print("Une méthode normale.")
    return self.num1 + self.num2 + num3

  @classmethod
  def mtd_class(cls, num3):
    print("Une methode de classe.")
    return cls.num1 + num3

  @staticmethod
  def mtd_statique(num3):
    print("Une methode statique.")
    return num3

Le mot self donne accès aux attributs d’instance dans une méthode d’instance et le mot cls fait référence à la classe pour nous permettre d’accéder aux attributs de la classe dans une méthode de classe.

Nous avons créé une classe Calcul qui possède une variable de classe num1 et une variable d’instance num2. Elle possède également une méthode de chaque type. Comme vous pouvez le constater, la méthode d’instance a accès aux états de la classe et de l’instance et elle prend comme paramètre self ou l’instance.

Cependant la méthode de class a uniquement accès à l’état de la classe et elle prend comme paramètre cls ou la classe elle même.

Quant à la méthode statique n’a accès à aucun des deux états, c’est à dire elle ne prend comme paramètre ni l’instance (self) ni la classe (cls).

obj1 = Calcul(20)
print(obj1.mtd_instance(30))
Une méthode normale
60

Pour appeler une méthode d’instance, nous devons instancier un objet. Si vous l’appelez directement avec la classe, vous aurez une erreur.

En fait, nous pouvons appeler la méthode de classe et la méthode statique à l’aide de l’instance ou de la classe.

obj1 = Calcul(20)

print(obj1.mtd_class(30))
print(Calcul.mtd_class(30))
print(obj1.mtd_statique(30))
print(Calcul.mtd_statique(30))
Une méthode de class
40
Une méthode de class
40
Une méthode statique
30
Une méthode statique
30

Il y a lieu de noter que le fait de pouvoir accéder à un attribut en utilisant le nom de la classe dans une méthode statique ne contredit pas ce qui a été dit. Les méthodes statiques doivent être complètement autonomes et ne fonctionner qu’avec des données transmises en tant qu’arguments.

De plus, une méthode statique peut être appelée sans créer d’objet ou d’instance.

En fait, il est plus judicieux d’appeler la méthode de classe en utilisant le nom de la classe, car elle est complètement liée à la classe.

Donc, ce que vous devez retenir est que les méthodes statiques fonctionnent comme des fonctions normales mais appartiennent à l’espace de noms de la classe. Les méthodes statiques n’ont pas accès à cls ou self, puisqu’elles ne sont pas passées comme paramètres.

Utilisation des méthodes de classe

Les méthodes de classe sont souvent utilisées comme constructeurs alternatifs ou comme méthodes de construction, c’est-à-dire pour créer des instances basées sur différents cas d’utilisation. Disons que nous avons une classe Etudiant ayant des attributs nom, note et date d‘admission.

Le constructeur prend la date d’admission sous la forme d’une année, d’un mois et d’un jour. Certains utilisateurs fournissent les informations dans ce format, mais d’autres donnent la date d’admission sous forme de chaîne de caractère «AAAA-MM-JJ». Pour la forme chaîne, nous utiliserons une méthode de classe comme constructeur alternatif, ce qui permettra à nos utilisateurs d’entrer des informations comme ils le souhaitent.

class Etudiant:
    def __init__(self, nom, note, annee, mois, jour):
        self.nom = nom
        self.note = note
        self.annee = annee
        self.mois = mois
        self.jour = jour

    @classmethod
    def chaîne(cls, nom, note, date_admission):
        annee, mois, jour = date_admission.split("-")
        return cls(nom, note, annee, mois, jour)

    def information(self):
        print(f"Nom: {self.nom}, Note: {self.note}")
        print(f"Date d'admission: Année: {self.annee}, Mois: {self.mois}, Jour: {self.jour}")

La méthode de classe chaîne() est utilisée comme constructeur alternatif pour diviser la chaîne là ou il y a un tiret-. La méthode information() affiche les informations de l’étudiant. Allons maintenant de l’avant et créons des instances de la classe Etudiant en utilisant le constructeur par défaut et alternatif.

etudiant1 = Etudiant("Marie", 10, 2005, 7, 1)
etudiant1.information()

L’exécution du code.

Nom: Marie, Note: 10
Date d‘admission: Année: 2005, Mois: 7, Jour: 1

Et.

etudiant2 = Etudiant.chaîne("Jack", 10, "2008-1-15")
etudiant2.information()

L’exécution du code.

Nom: Jack, Note: 10
Date d‘admission: Année: 2008, Mois: 1, Jour: 15

Les méthodes statiques

Les méthodes statiques sont utilisées pour créer des fonctions utiles. Ces méthodes ont une connexion logique avec la classe, mais n’utilisent pas l’état de la classe ou de l’objet. Ajoutons une méthode statique qui prend la moyenne d’un étudiant et affiche une observation. Cette méthode a une connexion logique avec la classe Etudiant, mais n’utilise pas ses propriétés ou ses méthodes.

class Etudiant:
    def __init__(self, nom, note, annee, mois, jour):
        self.nom = nom
        self.note = note
        self.annee = annee
        self.mois = mois
        self.jour = jour

    @classmethod
    def chaîne(cls, nom, note, date_admission):
        annee, mois, jour = date_admission.split("-")
        return cls(nom, note, annee, mois, jour)

    @staticmethod
    def observation(moyenne):
        if moyenne >= 15 and moyenne <= 20:
            return "Excellent"
        elif moyenne >= 12 and moyenne < 15:
            return "Bon travail"
        elif moyenne >= 10 and moyenne < 12:
            return "Moyen"
        else:
            return "Faible"

    def information(self):
        print(f"Nom: {self.nom}, Note: {self.note}")
        print(f"Date d'admission: Année: {self.annee}, Mois: {self.mois}, Jour: {self.jour}")

Nous allons tester notre méthode statique.

etudiant1 = Etudiant("Marie", 10, 2005, 7, 1)
print(etudiant1.observation(16))
Excellent

Les méthodes statiques ont un cas d’utilisation très clair. Lorsque nous avons besoin de fonctionnalités non pas par rapport à un objet mais par rapport à la classe, nous utiliserons une méthode statique. C’est assez avantageux lorsque nous devons créer des méthodes utiles car elles ne sont généralement pas liées au cycle de vie d’un objet.

À présent vous savez comment les décorateurs @classmethod et @staticmethod fonctionnent en Python.


1 commentaire

J.K · 9 février 2024 à 18 h 17 min

merci vous avez bien expliqué

Laisser un commentaire

Emplacement de l’avatar

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *