Najpierw zdefiniujmy przydatną funkcję do ustalenia, czy coś jest wykonywane, czy nie. Prosta funkcja, która przyjmuje argument, drukuje komunikat i zwraca dane wejściowe bez zmian.
>>> fun(1)
executed
1>>>1or fun(1)# due to short-circuiting "executed" not printed1>>>1and fun(1)# fun(1) called and "executed" printed
executed
1>>>0and fun(1)# due to short-circuiting "executed" not printed 0
Uwaga: Tłumacz uznaje następujące wartości za fałszywe:
FalseNone0""()[]{}
Zwarcie w funkcji: any(), all():
Python any()i all()funkcje obsługują również zwarcie. Jak pokazano w dokumentach; oceniają każdy element sekwencji w kolejności, aż do znalezienia wyniku, który umożliwia wcześniejsze wyjście z oceny. Rozważ poniższe przykłady, aby zrozumieć oba.
Funkcja any()sprawdza, czy którykolwiek element ma wartość True. Przestaje działać, gdy tylko zostanie napotkana wartość True i zwraca wartość True.
>>> any(fun(i)for i in[1,2,3,4])# bool(1) = True
executed
True>>> any(fun(i)for i in[0,2,3,4])
executed # bool(0) = False
executed # bool(2) = TrueTrue>>> any(fun(i)for i in[0,0,3,4])
executed
executed
executed
True
Funkcja all()sprawdza, czy wszystkie elementy są Prawdą i przestaje działać, gdy tylko pojawi się Fałsz:
>>> all(fun(i)for i in[0,0,3,4])
executed
False>>> all(fun(i)for i in[1,0,3,4])
executed
executed
False
Zwarcie w porównaniu łańcuchowym:
Dodatkowo w Pythonie
Porównania mogą być łączone dowolnie ; na przykład x < y <= zjest równoważne x < y and y <= z, z wyjątkiem tego, że yjest oceniane tylko raz (ale w obu przypadkach zw ogóle nie jest oceniane, gdy x < yzostanie uznane za fałszywe).
>>>5>6> fun(3)# same as: 5 > 6 and 6 > fun(3)False# 5 > 6 is False so fun() not called and "executed" NOT printed>>>5<6> fun(3)# 5 < 6 is True
executed # fun(3) called and "executed" printedTrue>>>4<=6> fun(7)# 4 <= 6 is True
executed # fun(3) called and "executed" printedFalse>>>5< fun(6)<3# only prints "executed" once
executed
False>>>5< fun(6)and fun(6)<3# prints "executed" twice, because the second part executes it again
executed
executed
False
Edycja:
Jeszcze jeden interesujący punkt do zapamiętania : - Logiczne and,or operatory w Pythonie zwracają wartość argumentu zamiast wartości logicznej ( Truelub False). Na przykład:
Operacja x and ydaje wynikif x is false, then x, else y
W przeciwieństwie do innych języków np &&, ||operatorów w C że powrót albo 0 albo 1.
Przykłady:
>>>3and5# Second operand evaluated and returned 5>>>3and()()>>>()and5# Second operand NOT evaluated as first operand () is false()# so first operand returned
Podobnie oroperator zwraca wartość najbardziej lewą, dla której bool(value)== Trueinna wartość najbardziej prawidłowa (zgodnie z zachowaniem zwarciowym), przykłady:
>>>2or5# left most operand bool(2) == True2>>>0or5# bool(0) == False and bool(5) == True5>>>0or()()
Jak to się przydaje? Jedno przykładowe zastosowanie podane w Practical Python Autor: Magnus Lie Hetland:
Powiedzmy, że użytkownik powinien wpisać swoje imię, ale może zdecydować się na nic, w takim przypadku chcesz użyć wartości domyślnej '<unknown>'. Możesz użyć instrukcji if, ale możesz też bardzo zwięźle stwierdzić:
In[171]: name = raw_input('Enter Name: ')or'<Unkown>'EnterName:In[172]: name
Out[172]:'<Unkown>'
Innymi słowy, jeśli zwracana wartość z raw_input ma wartość true (nie jest pustym ciągiem), jest przypisywana do name (nic się nie zmienia); w przeciwnym razie wartość domyślna '<unknown>'jest przypisana do name.
Drobne spory: wyraźna lista wartości fałszowania jest nieco myląca. Każdy typ może mieć jedną lub więcej wartości fałszowania. Zgodnie z przyjętą konwencją, wszystkie typy liczbowe o wartości 0są falsy (tak, to nie tylko 0, to 0.0, 0j, decimal.Decimal(0), fractions.Fraction(0), itd.), Podobnie jak wszystkie kolekcje o długości 0(tak na górze, co wymienione, b''[Py3] u''[PY2] i set()/ frozenset()są wszystkie wbudowane, które oceniają jako fałsz), ale typy zdefiniowane przez użytkownika / strony trzecie mogą definiować własne (za pomocą __bool__[Py3] / __nonzero__[Py2] bezpośrednio lub pośrednio poprzez zdefiniowanie __len__).
ShadowRanger
@ShadowRanger tutaj twój komentarz uzupełni moją odpowiedź. dzięki za dodanie tej notatki.
Odpowiedzi:
Tak, zarówno zwarcie , jak
and
ior
operatory - patrz dokumentacja .źródło
Zwarcie w zachowanie operatora
and
,or
:Najpierw zdefiniujmy przydatną funkcję do ustalenia, czy coś jest wykonywane, czy nie. Prosta funkcja, która przyjmuje argument, drukuje komunikat i zwraca dane wejściowe bez zmian.
Można zaobserwować na zwarcie zachowanie Pythona z
and
,or
operatorów w poniższym przykładzie:Uwaga: Tłumacz uznaje następujące wartości za fałszywe:
Zwarcie w funkcji:
any()
,all()
:Python
any()
iall()
funkcje obsługują również zwarcie. Jak pokazano w dokumentach; oceniają każdy element sekwencji w kolejności, aż do znalezienia wyniku, który umożliwia wcześniejsze wyjście z oceny. Rozważ poniższe przykłady, aby zrozumieć oba.Funkcja
any()
sprawdza, czy którykolwiek element ma wartość True. Przestaje działać, gdy tylko zostanie napotkana wartość True i zwraca wartość True.Funkcja
all()
sprawdza, czy wszystkie elementy są Prawdą i przestaje działać, gdy tylko pojawi się Fałsz:Zwarcie w porównaniu łańcuchowym:
Dodatkowo w Pythonie
Edycja:
Jeszcze jeden interesujący punkt do zapamiętania : - Logiczne
and
,or
operatory w Pythonie zwracają wartość argumentu zamiast wartości logicznej (True
lubFalse
). Na przykład:W przeciwieństwie do innych języków np
&&
,||
operatorów w C że powrót albo 0 albo 1.Przykłady:
Podobnie
or
operator zwraca wartość najbardziej lewą, dla którejbool(value)
==True
inna wartość najbardziej prawidłowa (zgodnie z zachowaniem zwarciowym), przykłady:Jak to się przydaje? Jedno przykładowe zastosowanie podane w Practical Python Autor: Magnus Lie Hetland:
Powiedzmy, że użytkownik powinien wpisać swoje imię, ale może zdecydować się na nic, w takim przypadku chcesz użyć wartości domyślnej
'<unknown>'
. Możesz użyć instrukcji if, ale możesz też bardzo zwięźle stwierdzić:Innymi słowy, jeśli zwracana wartość z raw_input ma wartość true (nie jest pustym ciągiem), jest przypisywana do name (nic się nie zmienia); w przeciwnym razie wartość domyślna
'<unknown>'
jest przypisana doname
.źródło
0
są falsy (tak, to nie tylko0
, to0.0
,0j
,decimal.Decimal(0)
,fractions.Fraction(0)
, itd.), Podobnie jak wszystkie kolekcje o długości0
(tak na górze, co wymienione,b''
[Py3]u''
[PY2] iset()
/frozenset()
są wszystkie wbudowane, które oceniają jako fałsz), ale typy zdefiniowane przez użytkownika / strony trzecie mogą definiować własne (za pomocą__bool__
[Py3] /__nonzero__
[Py2] bezpośrednio lub pośrednio poprzez zdefiniowanie__len__
).Tak. Spróbuj wykonać następujące czynności w interpreterie języka Python:
i
lub
źródło