python中布林型別
我們已經了解了python支援布林型別的資料,布林型別只有true和false兩種值,但是布林型別有以下幾種運算:
與運算:只有兩個布林值都為 true 時,計算結果才為 true。
true and true # ==> true
true and false # ==> false
false and true # ==> false
false and false # ==> false
或運算:只要有乙個布林值為 true,計算結果就是 true。
true or true # ==> true
true or false # ==> true
false or true # ==> true
false or false # ==> false
非運算:把true變為false,或者把false變為true:
not true # ==> false
not false # ==> true
布林運算在計算機中用來做條件判斷,根據計算結果為true或者false,計算機可以自動執行不同的後續**。
在python中,布林型別還可以與其他資料型別做 and、or和not運算,請看下面的**:
a = true
print a and 『a=t』 or 『a=f』
計算結果不是布林型別,而是字串 『a=t』,這是為什麼呢?
因為python把0、空字串」和none看成 false,其他數值和非空字串都看成 true,所以:
true and 『a=t』 計算結果是 『a=t』
繼續計算 『a=t』 or 『a=f』 計算結果還是 『a=t』
要解釋上述結果,又涉及到 and 和 or 運算的一條重要法則:短路計算。
在計算 a and b 時,如果 a 是 false,則根據與運算法則,整個結果必定為 false,因此返回 a;如果 a 是 true,則整個計算結果必定取決與 b,因此返回 b。
在計算 a or b 時,如果 a 是 true,則根據或運算法則,整個計算結果必定為 true,因此返回 a;如果 a 是 false,則整個計算結果必定取決於 b,因此返回 b。
所以python直譯器在做布林運算時,只要能提前確定計算結果,它就不會往後算了,直接返回結果。
a = 'python'
print
'hello,', a or
'world'
b = ''
print
'hello,', b or
'world'
執行結果如下:
hello, python
hello, world
Python中布林型別
我們已經了解了python支援布林型別的資料,布林型別只有true和false兩種值,但是布林型別有以下幾種運算 與運算 只有兩個布林值都為 true 時,計算結果才為 true。true and true true true and false false false and true false...
Python中布林型別
我們已經了解了python支援布林型別的資料,布林型別只有true和false兩種值,但是布林型別有以下幾種運算 與運算 只有兩個布林值都為 true 時,計算結果才為 true。true and true true true and false false false and true false...
Python中布林型別
我們已經了解了python支援布林型別的資料,布林型別只有true和false兩種值,但是布林型別有以下幾種運算 與運算 只有兩個布林值都為 true 時,計算結果才為 true。true and true true true and false false false and true false...