在Python中调用另一个类方法

时间:2010-06-04 18:42:05

标签: python

我想要创建一个包含对另一个类方法的引用的类。我希望能够调用该方法。它基本上是一种做回调的方法。

我的代码一直有效,直到我尝试访问类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()

3 个答案:

答案 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)