我该怎么做这样的事情:
class Foo():
do_stuff = {
"A" : lambda x: self.do_A(x),
"B" : lambda x: self.do_B(x)
}
def __init__(self):
print "hi"
def run(self):
muh = ['A', 'B', 'A']
for each in muh:
self.do_stuff[each](each)
def do_A(self, moo):
print "A"
def do_B(self, boo):
print "B"
if(__name__ == '__main__'):
aFoo = Foo()
aFoo.run()
这导致它给出一个错误,即自己没有在lambda函数中定义,但如果我删除它.它说没有定义do_A或do_B.
编辑
我设法搞清楚了.我需要将lambda表达式更改为以下内容:
lambda x, y: x.do_A(y)
我会称之为:
self.do_stuff[each](self, each)
这是一个糟糕的主意吗?
最佳答案 do_stuff不是示例中的实例变量.它更像是一个静态变量.您需要在方法(例如,init方法)中定义do_stuff,其中您具有对self的引用,以使其成为实例变量.我希望这个例子为你澄清一些事情:
class Foo:
def __init__(self):
self.do_stuff = { "A": self.do_A, "B": self.do_B }
def run(self):
for x in ["A", "B"]:
self.do_stuff[x]("hi")
def do_A(self, x):
pass
def do_B(self, x):
pass
请注意,lambda函数不是必需的.您只需在字典中存储对函数本身的引用即可.符号“self.do_A”将自动传递self作为第一个参数.
编辑:有谁知道如何使下划线在非代码示例文本中正确显示?
编辑:WTH?预览显示的下划线与帖子不同.