2

给定一个生成器对象,是否可以识别用于创建它的函数?

def gen_func():
    yield

gen = gen_func()

// From `gen`, how do I get a reference to `gen_func` ?

我正在实现一个装饰器,用于装饰带有附加属性的生成器函数。稍后我需要从生成器本身访问该属性。

4

1 回答 1

1

你真正要求的东西不可能以一种干净的方式实现,既因为生成器对象无法访问它们的生成器函数,又因为无法在生成器上创建新属性。

但是你想要达到的目标可能可能的。这是一个示例装饰器,它将生成器包装在迭代器对象中,并向迭代器对象添加自定义属性:

def add_stuff(f):
    def replacement(*args, **kwargs):
        gen = f(*args, **kwargs)
        class FakeGenerator(object):
            def __iter__(self):
                return self
            def next(self):
                return gen.next()
        fakegen = FakeGenerator()
        fakegen.foo = "whatever"
        fakegen.generator_function = f
        return fakegen
    return replacement

@add_stuff
def gen_func():
    yield

gen = gen_func()
print gen
print gen.foo
于 2013-03-29T03:14:10.177 回答