Précédent   Forum du club des développeurs et IT Pro > Autres langages > Python & Zope > Général Python
Général Python Forum d'entraide sur les fondamentaux du langage Python, syntaxe, POO, bibliothèque standard, ...
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse
 
Outils de la discussion
Publicité
'
Vieux 16/01/2013, 09h44   #1
ced733
Invité de passage
 
Inscription : janvier 2013
Messages : 2
Détails du profil
Informations forums :
Inscription : janvier 2013
Messages : 2
Points : 0
Points : 0
Par défaut Property et Class

Bonjour,

J'ai un petit problème de fonctionnalité avec les property.

Voici mon code :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
 
class Test2(object):
    def __init__(self,z=0):
        self.z = z
 
class Test(object):
    def __init__(self):
        self._var = Test2()
 
    def _get_var(self):
        return self._var
 
    def _set_var(self,var):
        self._var = var
        self.Fonction()
 
    var = property(_get_var,_set_var)
 
    def Fonction(self):
        print "Fonction"
 
a = Test()
a.var.z = 5
Ce que je souhaite, c'est que la fonction "Fonction" soit appelée lorsque je modifie a.var.z. Pas de soucis lorsque var est une simple variable, mais lorsque c'est un objet, cela ne marche plus vu que l'objet en soit n'est pas modifié.

J'ai trouvé un petite astuce en rajoutant :
Code :
1
2
 
a.var = copy.copy(a.var)
Mais ce n'est plus super trivial....

Une idée ?

Merci d'avance!
ced733 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/01/2013, 10h02   #2
utopman
Membre habitué
 
Homme eric
Ingénieur développement logiciels
Inscription : décembre 2010
Messages : 118
Détails du profil
Informations personnelles :
Nom : Homme eric

Informations professionnelles :
Activité : Ingénieur développement logiciels

Informations forums :
Inscription : décembre 2010
Messages : 118
Points : 117
Points : 117
Bonjour,

Je pense que tu peux utiliser un setter pour la propriété comme il suit :

Code :
1
2
3
4
5
6
7
8
9
10
11
 
class Test:
  z
  def setZ(self,newZ):
    self.customFunction() # l appel a lieu ici
    self.z = newZ # peut aussi être une copie
 
  def customFunction(self):
    ...
 
Test().setZ('X')
utopman est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/01/2013, 10h55   #3
ced733
Invité de passage
 
Inscription : janvier 2013
Messages : 2
Détails du profil
Informations forums :
Inscription : janvier 2013
Messages : 2
Points : 0
Points : 0
Salut, merci pour ta réponse.

Malheureusement, z est dans Test2. Quand à la fonction, elle doit absolument rester dans Test.
ced733 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/01/2013, 11h34   #4
wiztricks
Expert Confirmé Sénior
 
Inscription : juin 2008
Messages : 3 690
Détails du profil
Informations forums :
Inscription : juin 2008
Messages : 3 690
Points : 4 518
Points : 4 518
Salut,

Tel que je comprends, vous voulez pouvoir "observer" les accès à l'attribut "z" d'une instance de Test2 pour déclencher un callback lorsqu'il sera modifié.
Si on s'interdit de modifier Test2, on s'interdit de déclarer "directement" z comme attribut "observable".

Le faire indirectement suppose mettre une chose entre l'instance de Test2 et l'appelant qui "attrapera" les accès à l'instance.

"a.var.z = 5", fait get de "var" puis un set de "z", "la chose" ne peut se résumer à une property dans "Test" puisqu'on veut "attraper" ce qui se passe après Test mais avant "Test2".

Juste pour illustrer cela:

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
class Test2(object):
    def __init__(self,z=0):
        self.z = z
 
class proxy(object):
    def __init__(self, master, obj):
        self._object = obj
        self._master = master
 
    @property
    def z(self):
        return self._object.z
 
    @z.setter
    def z(self, value):
        self._object.z = value
        self._master.Fonction()
 
    def __getattr__(self, k):
        return getattr(self._object, k)
 
class Test(object):
    def __init__(self):
        self.var = proxy(self, Test2())
     def Fonction(self):
        print ("Fonction")
 
a = Test()
a.var.z = 5
- W
__________________
Architectures Post-Modernes
wiztricks est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse
Outils de la discussion

Navigation rapide


Fuseau horaire GMT +2. Il est actuellement 02h39.


 
 
 
 
Partenaires

Hébergement Web