我們已經了解了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'
在計算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'
a = 'python'
print 'hello,', a or 'world'
b = ''
print 'hello,', b or 'world'
輸出:
Python中布林型別
我們已經了解了python支援布林型別的資料,布林型別只有true和false兩種值,但是布林型別有以下幾種運算 與運算 只有兩個布林值都為 true 時,計算結果才為 true。true and true true true and false false false and true false...
Python中布林型別
python中布林型別 我們已經了解了python支援布林型別的資料,布林型別只有true和false兩種值,但是布林型別有以下幾種運算 與運算 只有兩個布林值都為 true 時,計算結果才為 true。true and true true true and false false false an...
Python中布林型別
我們已經了解了python支援布林型別的資料,布林型別只有true和false兩種值,但是布林型別有以下幾種運算 與運算 只有兩個布林值都為 true 時,計算結果才為 true。true and true true true and false false false and true false...