我想要创建一个包含对另一个类方法的引用的类。我希望能够调用该方法。它基本上是一种做回调的方法。
我的代码一直有效,直到我尝试访问类var。当我运行下面的代码时,我得到错误我做错了什么?
布赖恩
import logging
class yRunMethod(object):
"""
container that allows method to be called when method run is called
"""
def __init__(self, method, *args):
"""
init
"""
self.logger = logging.getLogger('yRunMethod')
self.logger.debug('method <%s> and args <%s>'%(method, args))
self.method = method
self.args = args
def run(self):
"""
runs the method
"""
self.logger.debug('running with <%s> and <%s>'%(self.method,self.args))
#if have args sent to function
if self.args:
self.method.im_func(self.method, *self.args)
else:
self.method.im_func(self.method)
if __name__ == "__main__":
import sys
#create test class
class testClass(object):
"""
test class
"""
def __init__(self):
"""
init
"""
self.var = 'some var'
def doSomthing(self):
"""
"""
print 'do somthing called'
print 'self.var <%s>'%self.var
#test yRunMethod
met1 = testClass().doSomthing
run1 = yRunMethod(met1)
run1.run()
答案 0 :(得分:11)
我认为你对自己的这种 WAY 太难了(这很容易做到;-)。类和实例的方法是Python中的第一类对象。你可以传递它们并像其他任何东西一样调用它们。深入挖掘方法的实例变量几乎不可能完成。实现目标的一个简单示例是:
class Wrapper (object):
def __init__(self, meth, *args):
self.meth = meth
self.args = args
def runit(self):
self.meth(*self.args)
class Test (object):
def __init__(self, var):
self.var = var
def sayHello(self):
print "Hello! My name is: %s" % self.var
t = Test('FooBar')
w = Wrapper( t.sayHello )
w.runit()
答案 1 :(得分:0)
为什么不使用它:
self.method(*self.args)
而不是:
if self.args:
self.method.im_func(self.method, *self.args)
else:
self.method.im_func(self.method)
答案 2 :(得分:0)
在您的代码中,您调用self.method.im_func(self.method)
- 您不应该将方法作为参数传递,而是传递该方法的对象。即应该是self.method.im_func(self.method.im_self, *self.args)