在字典中存储函数[Python]

时间:2015-03-24 23:47:23

标签: javascript python arrays dictionary data-structures

我目前正在构建一个应用程序,我需要迭代一系列基本相同的步骤,节省了非常少量的代码(~15行)。步骤数将根据项目的配置方式而有所不同,因此为每个潜在实例创建单独的函数似乎有点愚蠢。

在JavaScript中,我会做这样的事情:

var switches = [true, true, false, true];

var holder = {
    0: function() { /* do step0 */ }
    1: function() { /* do step1 */ }
    2: function() { /* do step2 */ }
    3: function() { /* do step3 */ }
    // ...etc...
}

for (var i = 0; i < switches.length; i++)
    if (switches[i])
        holder[i]();

有没有办法在python中做类似的事情?我唯一能想到的是这样的事情:

switches = [True, True, False, True]

class Holder(object):
    @staticmethod
    def do_0():
        # do step0

    @staticmethod
    def do_1():
        # do step 1

    # ...etc...

    def __repr__(self):
        return [self.do_0, self.do_1, ...]

for action in Holder:
    action()

如果我有大量的步骤,这似乎非常低效。还有什么更好的办法吗?

4 个答案:

答案 0 :(得分:3)

您可以按照以下方式执行此操作:

# define your functions
def fun1():
    print("fun1")

def fun2():
    print("fun2")

def fun3():
    print("fun3")


switches = [True, False, True];

# put them in a list (list makes more sense than dict based on your example)
func_list = [fun1, fun2, fun3]

# iterate over switches and corresponding functions, and execute 
# functions when s is True    
for s,f in zip(switches, func_list):
    if s: f() 

这只是一种方式。还有很多其他的。例如使用lambdas,dict如你所愿,等等。

如果你的函数只有一行,要使用lambdas,你可以这样做:

func_list = [lambda: print("lambda1"), 
             lambda: print("lambda2"), 
             lambda: print("lambda1")]

答案 1 :(得分:2)

看起来似乎没有办法在Python中做到这一点,因为它被解雇为非Pythonic而故意做出设计决定。哦,看起来我似乎无法定义方法,然后手动将它们添加到列表中以进行迭代。

来源:https://softwareengineering.stackexchange.com/a/99245

答案 2 :(得分:1)

- Your functions don't need to be enveloped in a utility class.
- I don not see how the two blocks of code differ in efficiency.
- You can use enumerate and lambdas to simplify your code.

简化代码

d = {0: lambda: 'Performing Step 0',
     1: lambda: 'Performing Step 1',
     2: lambda: 'Performing Step 2',
     3: lambda: 'Performing Step 3',
     4: lambda: 'Performing Step 4'}

for index, switch in enumerate([1, 0, 1, 1, 0]):
    if switch == 1: d[index]() 

答案 3 :(得分:-1)

我通常会这样做,如下所示。 我喜欢这种方法,因为它为代码添加了最少的打字开销,如果稍后再写一个额外的方法,则不需要在文件的其他地方修改任何内容。

def steptest0():
    code
def steptest1():
    code
def steptest2():
    code

...

tests = filter(lambda x: x.startswith('steptest'),
               dir())
for t in tests: eval(t + '()')

每个方法都已经在Python中自动放入字典中,dir()允许我们访问它。

声明。在看到“eval”的情况下,普通行人狂热者的头部开始出现多个警钟,有些甚至可能有癫痫发作。让他们通过使用反射机制来保护自己免受eval的影响(这可能使其不太可读,但仍然值得,因为他们不能被指责使用“eval”)。