Classe abstraite [Résolu]

cs_oxkao 7 Messages postés samedi 24 janvier 2009Date d'inscription 5 mai 2010 Dernière intervention - 2 juin 2009 à 15:16 - Dernière réponse : cs_oxkao 7 Messages postés samedi 24 janvier 2009Date d'inscription 5 mai 2010 Dernière intervention
- 5 juin 2009 à 09:24
bonjours,

voili voilou je me suis mis à python et je pensais (en tant que langage objet) retrouver les mêmes principe qu'en C++ ou java

je cherche donc à avoir une classe (abstraite) avec des attributs qui seront commun à plusieurs classe
genre :

abstract class Composant
string  nom
int num
class Ecran
int taille
class Souris
int nbBouton
je souhaiterais que mes classe Ecran et Souris hérite des attribut de la classe composant

heu j'ai trouver sa : http://iihm.imag.fr/blanch/howtos/Python.html
mais j'ai rien compris au duck typing
en gros je pensais faire une classe
class Composant (object):

    def __init__(self,__nom,__numSerie,__marque):
        self.__nom = __nom
        self.__numSerie = __numSerie
        self.__marque = __marque
et faire hériter à mes autre classe
import composant
class Ecran (Composant):

    def __init__(self,__taille,__nom,__numSerie,__marque):
        self.__taille =__taille
        self.__nom = __nom
        self.__numSerie =__numSerie
        self.__marque = __marque
mais en fait le souci c'est que je pourrais toujours (si la folie m'envahis un bref instant) faire une instanciation de la classe Composant
un peu perturbant

en plus je galère un peu pour les variables je suis pas encore très au point  du faite qu'on est pas besoin d'assesseur get et set et que rien ne soit privée en python :/

merci d'avance
Afficher la suite 

Votre réponse

4 réponses

Meilleure réponse
cs_gaulthier 9 Messages postés samedi 2 juin 2007Date d'inscription 3 juin 2009 Dernière intervention - 3 juin 2009 à 13:07
3
Merci
Pour l'héritage de classe :

class Composant ():
    def __init__(self, nom, numSerie, marque):
        self.nom = nom
        self.numSerie = numSerie
        self.marque = marque

    def affichage(self):
        print self.nom, self.numSerie, self.marque,

class Ecran (Composant):
    def __init__(self,taille,nom,numSerie,marque):
        #Héritage des attributs et méthodes de Composant
        Composant.__init__(self, nom, numSerie, marque)

        self.taille = taille

    def affichage(self):
        #Surcharge de la méthode affichage de Compsant
        Composant.affichage(self)
        print self.taille

a = Ecran(22,"toto ^_^", "jenesaisquoimettre", "Toshiba")
a.affichage()

Jsp que l'exemple sera assez claire :)

Merci cs_gaulthier 3

Avec quelques mots c'est encore mieux Ajouter un commentaire

Codes Sources a aidé 89 internautes ce mois-ci

Commenter la réponse de cs_gaulthier
Meilleure réponse
cs_oxkao 7 Messages postés samedi 24 janvier 2009Date d'inscription 5 mai 2010 Dernière intervention - 5 juin 2009 à 09:24
3
Merci
merci pour l'aide gaulthier :D

pour les classes abstraite j'ai juste pas mis de méthode à une classe "normale" ^^

sa marche bien

sinon j'ai eu un autre souci au niveau de l'héritage quand je voulais hérité d'un  d'un objet se situant dans un autre fichier sa merdouillais

problème résolut grâce à:    from animaux import Poule :)

Merci cs_oxkao 3

Avec quelques mots c'est encore mieux Ajouter un commentaire

Codes Sources a aidé 89 internautes ce mois-ci

Commenter la réponse de cs_oxkao
cs_oxkao 7 Messages postés samedi 24 janvier 2009Date d'inscription 5 mai 2010 Dernière intervention - 2 juin 2009 à 15:47
0
Merci
bon j'ai ni trouver le bouton des balises de code ni le bouton éditer :/
ducoup je double post ...

hum si j'ai bien compris (oulà -.-) suffit de rajouter :
raise NotImplementedError

pour que ma méthode soit virtuel ? (toujours d'après  : http://iihm.imag.fr/blanch/howtos/Python.html )
donc si je fais :
class Composant (object):

    def __init__(self,__nom,__numSerie,__marque):
        self.__nom = __nom
        self.__numSerie = __numSerie
        self.__marque = __marque
raise NotImplementedError 
#j'arrive pas à suppr la ligne blanche -.- décidément se forum m'aime pas
ma classe Composant ne pourra pas être implémenter ?
donc impossible de faire :
toto = composant.Composant("yop",123456,"glop")
Commenter la réponse de cs_oxkao
cs_oxkao 7 Messages postés samedi 24 janvier 2009Date d'inscription 5 mai 2010 Dernière intervention - 2 juin 2009 à 16:29
0
Merci
woot triple post -.-
de grace que quelqu'un me mp pour me dire comment éditer mes post ^^"

bon j'ai tenter de faire sa dans un seul fichier pour simplifier la vie et tenter d'élucider le problème :
#!/usr/bin/python
#-*- coding: utf-8 -*-

class Machine (object):
   
    def __init__(self,__numAfpa=0,__nomSymbolique=0,__dateAchat=0,__dateFinGarantie=0,):
        self.__numAfpa = __numAfpa
        self.__nomSymbolique = __nomSymbolique
        self.__dateAchat = __dateAchat
        self.__dateFinGarantie =__dateFinGarantie
        print"sortie de la méthode __init__"
   
    def affiche(self):
        print self.__numAfpa
        print self.__nomSymbolique
        print self.__dateAchat
        print self.__dateFinGarantie

class Test (Machine):
   
        def __init__(self,__zea=5,__numAfpa=0,__nomSymbolique=0,__dateAchat=0,__dateFinGarantie=0,):
            self.__zea =__zea
            Machine.__init__(self,__numAfpa,__nomSymbolique,__dateAchat,__dateFinGarantie,)
       

le souci c'est que dans mon fichier testMain.py (qui est dans le même dossier =) )
m1 = machine.Machine (1,2,3,4)
m1.affiche()
#bon sa sa fonctionne pas de souci =p

mais quand je fais :
m2 = machine.Test(1,2,3,4,5)
print m2.__zea

Traceback (most recent call last):
  File "testMain.py", line 13, in <module>
    print m2.__zea
AttributeError: 'Test' object has no attribute '__zea'

='(  Comment ca il à pas d'attribut nommé __zea mon Test oO

pfiou je suis largué -.-

ps dsl du triple post :S
Commenter la réponse de cs_oxkao

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.