假设我有以下代码:
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
是否有更好(更安全?)的方式来实现这一目标?
答案 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