Где символы амперсанда и вертикальной черты используются в Python?
На странице Википедии, описывающей оценку короткого замыкания, &
а также |
перечислены как активные операторы в Python. Что это значит и когда они используются в языке?
3 ответа
Страница википедии неверна, я исправил это. |
а также &
не являются булевыми операторами, даже если они нетерпеливые операторы, что означает, что они не являются операторами короткого замыкания. Как вы, наверное, знаете, вот как питон and
а также or
операторы работают:
>>> def talk(x):
... print "Evaluating: ", bool(x)
... return x
...
>>> talk(1 == 1) or talk(2 == 1) # 2 == 1 is not evaluated
Evaluating: True
True
>>> talk(1 == 1) and talk(2 == 1)
Evaluating: True
Evaluating: False
False
>>> talk(1 == 2) and talk(1 == 3) # 1 == 3 is not evaluated
Evaluating: False
False
Насколько я знаю, в python нет активных логических операторов, их нужно было бы явно кодировать, например, так:
>>> def eager_or(a, b):
... return a or b
...
>>> eager_or(talk(1 == 1), talk(2 == 1))
Evaluating: True
Evaluating: False
True
Сейчас a
а также b
автоматически оцениваются при вызове функции, даже если or
по-прежнему короткие замыкания.
Что касается использования |
а также &
при использовании с числами они являются бинарными операторами:
>>> bin(0b11110000 & 0b10101010)
'0b10100000'
>>> bin(0b11110000 | 0b10101010)
'0b11111010'
Вы, скорее всего, будете использовать |
таким образом с привязками Python к библиотекам, которые используют флаги, такие как wxWidgets:
>>> frame = wx.Frame(title="My Frame", style=wx.MAXIMIZE | wx.STAY_ON_TOP)
>>> bin(wx.MAXIMIZE)
'0b10000000000000'
>>> bin(wx.STAY_ON_TOP)
'0b1000000000000000'
>>> bin(wx.MAXIMIZE | wx.STAY_ON_TOP)
'0b1010000000000000'
При использовании с наборами они выполняют операции пересечения и объединения соответственно:
>>> set("abcd") & set("cdef")
set(['c', 'd'])
>>> set("abcd") | set("cdef")
set(['a', 'c', 'b', 'e', 'd', 'f'])
В других ответах чего-то не хватает, так это того, что &
а также |
не имеют универсального значения в Python; их значение зависит от типов операндов, используя магию__and__
а также __or__
методы. Так как это методы, оба операнда оцениваются (т. Е. Без короткого замыкания) перед передачей в качестве аргументов.
На bool
значениями они являются логическим "и" и логическим "или":
>>> True & False
False
>>> True | False
True
>>> bool.__and__(True, False)
False
>>> bool.__or__(True, False)
True
На int
значения они побитовое "и" и побитовое "или":
>>> bin(0b1100 & 0b1010)
'0b1000'
>>> bin(0b1100 | 0b1010)
'0b1110'
>>> bin(int.__and__(0b1100, 0b1010))
'0b1000'
>>> bin(int.__or__(0b1100, 0b1010))
'0b1110'
На множествах это пересечение и объединение:
>>> {1, 2} & {1, 3}
{1}
>>> {1, 2} | {1, 3}
{1, 2, 3}
>>> set.__and__({1, 2}, {1, 3})
{1}
>>> set.__or__({1, 2}, {1, 3})
{1, 2, 3}
Пара дополнительных замечаний:
- В
__and__
а также__or__
методы всегда ищутся в классе, а не в экземпляре. Итак, если вы назначитеobj.__and__ = lambda x, y: ...
тогда это все ещеobj.__class__.__and__
это вызвано. - В
__rand__
а также__ror__
методы класса будут иметь приоритет, если они определены.
Подробнее см. В справочнике по языку Python.
Это означает, что левый операнд и правый операнд всегда оцениваются. &
является побитовым оператором И и |
является побитовым оператором ИЛИ.
& ----> Используется для AND поразрядно, т.е.
так же,
| ---> используется для побитового ИЛИ
Когда вы обнаружите какие-либо проблемы с питоном, попробуйте использовать python.org, это полезно