L'objectif principal du module suivant est de fournir une sorte de sémantique "constante" pour certains noms.L'accès par attribut surchargé ne fonctionne pas (comme prévu)
class ConstantError(Exception):
def __init__(self, msg):
self._msg = msg
class Constant(object):
def __init__(self, name):
self._name = name
def __get__(self, instance, owner):
return instance._content[self._name]
def __set__(self, instance, value):
raise ConstantError, 'Illegal use of constant'
class Constants(object):
def __init__(self, content):
self._content = content
for k in self._content:
setattr(self, k, Constant(k))
num_const = Constants({
'one': 1,
'two': 2
})
Quand il est utilisé:
>>> from const import *
>>> dir(num_const)
['__class__', '__delattr__', '__dict__', '__doc__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__str__', '__weakref__', '_content', 'one', 'two']
Alors one
et two
sont là, mais l'accès d'attribut est diappointing:
>>> num_const.one
<const.Constant object at 0x7faef4871710>
>>>
Là où je Wold attendre 1
dans ce cas. Où ai-je tort?
Voilà donc le point. Pourriez-vous nous éclairer sur la raison d'être de ce comportement? Je veux dire, quoi d'autre pourrait mal tourner si le protocole des descripteurs fonctionnait également sur les instances de classe? –
Je ne sais pas exactement pourquoi. Les problèmes de performance pour l'accès aux attributs? Ou qu'il serait difficile d'accéder à l'attribut lui-même (le descripteur) sans l'invoquer. – u0b34a0f6ae