views:

115

answers:

2

Why I can't redefine the __and__ operator?

class Cut(object):
      def __init__(self, cut):
         self.cut = cut
      def __and__(self, other):
         return Cut("(" + self.cut + ") && (" + other.cut + ")")

a = Cut("a>0") 
b = Cut("b>0")
c = a and b
print c.cut()

I want (a>0) && (b>0), but I got b, that the usual behaviour of and

+5  A: 

__and__ is the binary (bitwise) & operator, not the logical and operator.

Because the and operator is a short-circuit operator, it can't be implemented as a function. That is, if the first argument is false, the second argument isn't evaluated at all. If you try to implement that as a function, both arguments have to be evaluated before the function can be invoked.

Ned Batchelder
Note that you *could* allow overloading of `and` with short circuiting by providing a more complex interface, as has been suggested for Python (http://www.python.org/dev/peps/pep-0335/), though it is not supported.
Mike Graham
Interesting, I hadn't seen that PEP.
Ned Batchelder
+2  A: 

because you cannot redefine a keyword (that's what and is) in Python. __add__ is used to do something else:

These methods are called to implement the binary arithmetic operations (...&...

SilentGhost