Binding first parameter of method to constant value

DPalao dpalao.python at gmail.com
Fri May 18 09:04:12 EDT 2012


On Viernes mayo 18 2012 14:14:33 Johannes Bauer escribió:
> Hi group,
>> I'm trying to dynamically add methods to a class at runtime. What I
> would like to do is have them all delegated to one common function which
> is called with the name of the function as first parameter. I.e.:
>> class Foo():
> def __init__(self):
> # Some magic missing here
> setattr(self, "foometh", types.MethodType(self._dispatcher, self))
> setattr(self, "barmeth", types.MethodType(self._dispatcher, self))
>> def _dispatcher(self, caller, *args):
> # Dispatcher called with caller == "foometh"
> # or caller == "barmeth", depending on which one was called
>>> with the effect that
>> f = Foo()
> f.foometh(1, 2, 3)
> # -> this should be equivaent to Foo._dispatcher(f, "foometh", 1, 2, 3)
>> f.barmeth()
> # -> this should be equivaent to Foo._dispatcher(f, "barmeth")
>> I'm kind of stuck. Can you please give me hints?
>> Best regards,
> Joe
>> >> Wo hattest Du das Beben nochmal GENAU vorhergesagt?
> > 
> > Zumindest nicht öffentlich!
>> Ah, der neueste und bis heute genialste Streich unsere großen
> Kosmologen: Die Geheim-Vorhersage.
> - Karl Kaos über Rüdiger Thomas in dsa <hidbv3$om2$1 at speranza.aioe.org>

Hi Johannes,
If I understood well your question, for specific attributes I recommend you to 
have a look at properties and descriptors (I love them).
For a general way to deal with attributes: the __getattr__ (to handle 
undefined attributes), __getattribute__ (to handle *every* attribute; be 
careful with loops), and __setattr__ (to catch *every* attribute assignmet, 
same warning concerning loops).
Hope it helps.
BR,
DPalao


More information about the Python-list mailing list

AltStyle によって変換されたページ (->オリジナル) /