如何在python中定义自己的前缀和后缀运算符

时间:2013-11-06 17:18:55

标签: python math operators

此问题是上一个问题(Python: defining my own operators?)的扩展。我真的很喜欢Infix运算符的solution provided there,但对于我的表达式,我需要一种方法来以类似的方式定义自定义一元运算符。

你有什么建议吗?重用现有的python运算符并没有帮助,因为我已经全部使用它们了。非常感谢你的帮助!

执行此重载的主要原因是Python中缺少以下一元运算符:    (是> 0)    (是> = 0) 我需要运算符来区分这两种类型的操作,我的要求是尽可能地将我的接口与由自己的一组运算符附带的预定义语言提供的接口相匹配。我可以选择用>替换运算符0和> = 0但是这与用户社区的关系不是很好。有更好的方法吗?

1 个答案:

答案 0 :(得分:1)

嗯,你可以使用相同的黑客:

#! /usr/bin/python3.2

class Postfix:
    def __init__(self, f):
        self.f = f

    def __ror__(self, other):
        return self.f(other)

x = Postfix(lambda x: x * 2)

a = 'Hello'
print(a |x)
a = 23
print(a |x |x)

尽管如此,我不主张使用它,因为它只是令人困惑。

编辑:特别是当你的操作符是一元的时候,你可以简单地调用一个函数,任何阅读你代码的人都会立即理解它的作用。

def choose(t): pass
    #magic happens here and returns nCr(t[0], t[1])

nCr = Postfix(choose)

#This is unintuitive:
print((3, 4) |nCr)

nCr = choose

#But this is obvious:
print(nCr((3, 4)))

编辑2:亲爱的有关PEP-8的人:这个“操作员” - ha都是不遵守PEP-8,所以请停止编辑答案。我的想法是|op被读取为一个实体,基本上是一个后缀运算符。


编辑3:努力思考这个黑客可以派上用场的情况,也许以下可能是一个合理的用途。 (当且仅当API中有详细记录此功能时):

#! /usr/bin/python3.2

class Language:
    def __init__(self, d):
        self.d = d

    def __ror__(self, string):
        try: return self.d[string]
        except: return string

enUS = Language({})
esMX = Language({'yes': 'sí', 'cancel': 'cancelar'})
deDE = Language({'yes': 'ja', 'no': 'nein', 'cancel': 'abbrechen'})

print('yes' |enUS)
print('no' |deDE)
print('cancel' |esMX)