通过字符串名称以编程方式查找运算符

时间:2019-01-04 18:59:37

标签: python operators

假设我有以下代码:

def process(x, y, op):
    if op == 'eq':
        return x == y
    elif op == 'gt':
        return x > y
    elif op == 'lt':
        return x < y
    ... for many more operators, e.g. >=, <=, !=

我该如何通过编程将其简化?我正在考虑创建这样的查找:

op_lookup = {'eq': '==', 'gt': '>', 'lt': '<', ...}

然后做这样的事情:

def process(x, y, op):
    return x op_lookup[op] y

显然不是有效的Python ...

类似eval的方法可能会起作用:

def process(x, y, op):
    return eval('{} {} {}'.format(x, op_lookup[op], y))
在一个示例中,

是哪个产生的:

>>> process(1, 1, 'eq')
True
>>> process(1, 1, 'lt')
False

是否有更好(更安全?)的方式来实现这一目标?

2 个答案:

答案 0 :(得分:6)

作为可调用对象的运算符隐藏在operator模块中。您可以使用内置getattr的名称来动态访问特定运算符。

演示:

>>> import operator         
>>> getattr(operator, 'eq')(1, 1)
True
>>> getattr(operator, 'eq')(1, 2)
False
>>> getattr(operator, 'lt')(1, 2)
True
>>> getattr(operator, 'lt')(2, 1)
False

我们可以使用它来重写您的函数,如下所示。

import operator

def process(x, y, op):
    return getattr(operator, op)(x, y)

(根据需要添加健全性检查。)

答案 1 :(得分:4)

operator模块是您想要的:

>>> import operator
>>> op_lookup = {'eq': operator.eq, 'gt': operator.gt, 'lt': operator.lt}
>>> 
>>> def process(x, y, op):
...     return op_lookup[op](x, y)
... 
>>> process(1, 1, 'eq')
True
>>> process(1, 1, 'lt')
False