布尔类型其实可以算是一种特殊的数字,下面是 help() 函数得到的帮助信息:

布尔代数化简 用python 布尔函数python_python布尔类型运算

布尔代数化简 用python 布尔函数python_布尔代数化简 用python_02

Help on class bool in module __builtin__:classbool(int)| bool(x) ->bool|
| Returns True when the argument x istrue, False otherwise.| The builtins True and False are the only two instances of the classbool.| The class bool is a subclass of the class int, andcannot be subclassed.|
|Method resolution order:|bool|int|object|
|Methods defined here:|
| __and__(...)| x.__and__(y) <==> x&y|
| __or__(...)| x.__or__(y) <==> x|y|
| __rand__(...)| x.__rand__(y) <==> y&x|
| __repr__(...)| x.__repr__() <==>repr(x)|
| __ror__(...)| x.__ror__(y) <==> y|x|
| __rxor__(...)| x.__rxor__(y) <==> y^x|
| __str__(...)| x.__str__() <==>str(x)|
| __xor__(...)| x.__xor__(y) <==> x^y|
| ----------------------------------------------------------------------
| Data andother attributes defined here:|
| __new__ = 
| T.__new__(S, ...) ->a new object with type S, a subtype of T|
| ----------------------------------------------------------------------
| Methods inherited fromint:|
| __abs__(...)| x.__abs__() <==>abs(x)|
| __add__(...)| x.__add__(y) <==> x+y|
| __cmp__(...)| x.__cmp__(y) <==>cmp(x,y)|
| __coerce__(...)| x.__coerce__(y) <==>coerce(x, y)|
| __div__(...)| x.__div__(y) <==> x/y|
| __divmod__(...)| x.__divmod__(y) <==>divmod(x, y)|
| __float__(...)| x.__float__() <==>float(x)|
| __floordiv__(...)| x.__floordiv__(y) <==> x//y|
| __format__(...)|
| __getattribute__(...)| x.__getattribute__('name') <==>x.name|
| __getnewargs__(...)|
| __hash__(...)| x.__hash__() <==>hash(x)|
| __hex__(...)| x.__hex__() <==>hex(x)|
| __index__(...)| x[y:z] <==> x[y.__index__():z.__index__()]|
| __int__(...)| x.__int__() <==>int(x)|
| __invert__(...)| x.__invert__() <==> ~x|
| __long__(...)| x.__long__() <==>long(x)|
| __lshift__(...)| x.__lshift__(y) <==> x<
| __mod__(...)| x.__mod__(y) <==> x%y|
| __mul__(...)| x.__mul__(y) <==> x*y|
| __neg__(...)| x.__neg__() <==> -x|
| __nonzero__(...)| x.__nonzero__() <==> x !=0|
| __oct__(...)| x.__oct__() <==>oct(x)|
| __pos__(...)| x.__pos__() <==> +x|
| __pow__(...)| x.__pow__(y[, z]) <==>pow(x, y[, z])|
| __radd__(...)| x.__radd__(y) <==> y+x|
| __rdiv__(...)| x.__rdiv__(y) <==> y/x|
| __rdivmod__(...)| x.__rdivmod__(y) <==>divmod(y, x)|
| __rfloordiv__(...)| x.__rfloordiv__(y) <==> y//x|
| __rlshift__(...)| x.__rlshift__(y) <==> y<
| __rmod__(...)| x.__rmod__(y) <==> y%x|
| __rmul__(...)| x.__rmul__(y) <==> y*x|
| __rpow__(...)| y.__rpow__(x[, z]) <==>pow(x, y[, z])|
| __rrshift__(...)| x.__rrshift__(y) <==> y>>x|
| __rshift__(...)| x.__rshift__(y) <==> x>>y|
| __rsub__(...)| x.__rsub__(y) <==> y-x|
| __rtruediv__(...)| x.__rtruediv__(y) <==> y/x|
| __sub__(...)| x.__sub__(y) <==> x-y|
| __truediv__(...)| x.__truediv__(y) <==> x/y|
| __trunc__(...)|Truncating an Integral returns itself.|
|bit_length(...)| int.bit_length() ->int|
| Number of bits necessary to represent self inbinary.| >>> bin(37)| '0b100101'
| >>> (37).bit_length()| 6
|
|conjugate(...)|Returns self, the complex conjugate of any int.|
| ----------------------------------------------------------------------
| Data descriptors inherited fromint:|
|denominator| the denominator of a rational number inlowest terms|
|imag|the imaginary part of a complex number|
|numerator| the numerator of a rational number inlowest terms|
|real| the real part of a complex number
bool

首先,请注意这一行:

布尔代数化简 用python 布尔函数python_布尔代数化简 用python_03

其父类为 int 而且其内置方法也是一模一样,也就是说布尔类型也是可以和整型一样进行各种运算的,但一般没有人那么做。

布尔类型只有两个值: True 和 False ,或者说只返回两个值。

注意:python是严格区分大小写的,别写错了。

一般布尔值是用于流程控制的,下面我们来讲讲python中的流程控制是怎么样的。

但是,在这之前,我们要先了解python的缩进和编程风格。

首先,python代码的执行是从上往下逐一解释的,而如果大家开头都是对齐的话:

布尔代数化简 用python 布尔函数python_python布尔类型运算_04

布尔代数化简 用python 布尔函数python_python布尔类型运算_05

大家都是同级的,就会逐条执行,这个例子还说明了什么叫逐条执行,当我执行的 print d 时,d的赋值操作却在后面,所以进行打印操作的时候,没找到这个变量的值,所以抛出了给变量没定义的错误。

而我们要进行流程控制的操作的时候,我们希望的效果是这样的:

a = 1

if a == 1: #如果a的值等于1的话,注意赋值运算符和比较运算符号的差别

print a #我就打印出a的值

假设这里没有语法问题,python从第一句开始执行,当判断完 if 之后,又换行继续执行。

本来我们是想让 if 来控制 print 执行的,但 print 表示不服,大家都是同一级的,你 if 凭什么管我?

当然,这种写法是一种语法错误。

布尔代数化简 用python 布尔函数python_布尔代数化简 用python_06

所以,我们可以认为缩进是python控制优先级的,它规定了代码间的管辖问题。(这是我自己总结的)

但是,当我们学到函数,学到类的写法的时候,发现其也是要进行缩进的,而函数中又有一个作用域的问题(到时候详细讲),在函数作用域中又有一个现象,函数内外的变量是不能互相访问的(当然也有强制的方法),此时有人就会搞混了,是不是我这里流程控制使用缩进分了内外分层后,内层的变量在外层也是不能访问的?

不是,下面是实例:

a = 1
if a == 1:
b= 1
else:
b=0print b

布尔代数化简 用python 布尔函数python_缩进_07

是可以访问的,注意作用域是函数的东西,不要混到流程控制里面起来,为了方便大家了解,我画了下面这幅图:

布尔代数化简 用python 布尔函数python_布尔代数化简 用python_08

是这为了方便大家了解才画的图,具体python内部是不是这样处理的我也不知道。

在缩进的时候可以使用制表符(tab键)和空格,官方推荐是4个空格,但这两种缩进方式是不能混用的。

但是,如果我们使用IDE编程(部分,pycharm中是这样)的话,当我们按下 tab 键的时候,IDE会输入若干个空格(默认个数也因IDE不同而不同),也就是我们认为我们输入的是 tab 键的制表符,其实输入的是空格,这点要注意。

关于python中的编程风格可以总结为:

Python 使用硬回车来分割语句(一句一行,一行写不下用 \ 换行),使用冒号(:)和缩进来分割代码块。同一层次的语句必须有相同的缩进(每一组这样的语句称为一个块),而C语言风格的编程语言(Java/C#/C++)则使用分号来分割语句,花括号来分割代码块。

1.if 语句

python中使用 if...elif...else... 来实现条件判断:

a = 1
if a == 1:
b= 1
elif a == 2:
b= 2
elif a == 3:
b= 3
else:
b=0print b

python会从上到下进行判断,如何条件为真,即布尔值为 True ,其内层的代码才会被执行。

布尔代数化简 用python 布尔函数python_缩进_09

这里比较运算符返回了布尔值,但是如果条件不是布尔值或者没有返回布尔值要怎么判断。

其实,当我们用某个作为判断条件是,其实已经隐性地声明要使用 bool() 函数将条件强制转换为布尔值了。

布尔代数化简 用python 布尔函数python_布尔代数化简 用python_10

我们可以将不是bool类型的数据强制转换成bool值。那究竟它们之间的转换关系是什么呢?

下面是一些关于布尔值为假的总结:

1.数字0(0.0等浮点型也是)

2.空的数据(包括空的字符串,空元祖,空列表,空字典,空集合等)

3.None(空的对象)

除了上面为假之外,其他均为真。

注意,虽说在将布尔值强行转换成数字的时候:

布尔代数化简 用python 布尔函数python_布尔代数化简 用python_11

True转换成 1,但并不是说只有数字中只有 1 为真,只要不为0的数字都是真。

讲完布尔值的问题是时候分析语法了,首先,语法和核心就是使用关键字判断其布尔值是否为真,若为真,则执行内层的代码。

if 和 elif 里面都可以放条件,而 else 则表示如果上面的条件都不为真,则执行这里面的。

但要注意几个问题,一个判断组有且至少有一个 if ,可以有0个或多个 elif ,0个或1个else。(判断组也是我总结的东西,我也不知道python中有没有关于判断组的定义)

a = 1b=0if a ==0:
b= 1
if a == 1:
c= 1
else:
b= 3
printbprint c

布尔代数化简 用python 布尔函数python_缩进_12

即为第一组的 if 判断失败后,不能去执行第二组判断的 else。

另外,还有这种情况:

布尔代数化简 用python 布尔函数python_布尔代数化简 用python_13

有两个条件是一样的,这种情况会怎么样,我们先看看结果:

布尔代数化简 用python 布尔函数python_缩进_14

很明显只有第一个为真的有效果了,所以我们可以得出以下结论:

一个判断组里面,一旦条件为真,这个判断组内剩下的判断就不继续进行了,当然我相信应该没有会写两个一样的条件吧。

三元运算

在讲完if语句之后,我们就可以学习三元运算了。

何为三元运算,这个名字看起来很高端,但其实是为了满足:我要为一个变量赋值,当满足一个条件时,这个变量的值应该是123,不满足的话值为456。

a =???if a == 1:

b= 1eles:

b= 2

但这样写还是太烦,有没有简单点的写法?

有,我们可以使用三元运算:

b = 1 if a==1 else 2

总结起来就是:

b = 值1 if 条件 else 值2

这就是三元运算,就是这么简单,so easy。 说白了就是一种高级的赋值方式,就算不用三元运算,用原始的写法也是可以的。

2. while循环

本来while循环应该放到循环里面讲的,但是while循环和bool值的关系比较密切,就在这里一并讲了。

首先 while 循环的意思是,当给定的条件为真的时候,就会对其内层的代码循环执行,从内层第一句执行到最后一句。执行完以后又回到while中继续判断条件,若还是为真,则继续执行,如此往复,直到条件为假。

a = 1
while a <= 5:
a+= 1
printaprint '----',a

布尔代数化简 用python 布尔函数python_python布尔类型运算_15

注意,最后一句 print '----',a不在while的内层,不受while的控制,只要while执行完了,就一定会执行它。

这个时候,有同学要问,如果我给的条件永远为真, while True: 那会怎么样?

那么,这时候要恭喜你,你进入了传说中的死循环,这个循环永远执行不完了,其后面的代码也不会执行了,这个时候连退出都要用 ctrl+c 强制退出了。

正是因为while循环这么危险,所以有两个关键字可以用来跳过循环 :

continue 跳过本次循环

break   跳出整个while循环,当然有多个 while 嵌套时,只跳出当前这层

那么什么叫本次,什么叫整个,什么叫当前这层呢?

假如,有一天你在街上摆摊,生意很好,人们都排队来买,这个人买完就下一个。但是,此时你看到一个人长得奇丑无比,你不想卖给他,没办法,有钱任性呗。这是你大喊一声:东西不卖你,下一个继续(continue),这就是跳过本次循环,遇到这句时,下面的代码不继续执行了,继续回到循环的第一句执行。当然那个被你拒卖的人后来会不会找人揍你,这就不在考虑范围了。这个时候,又来个一个客人,你定睛一看,我去,城管!赶紧跑!这个时候你摆摊的行为就结束了,也就是 while 循环结束了,就算你的指定条件是到下午5点收摊的也没办法,这就是 break。但虽然摆摊结束了,但你还得继续生活呀,生活也是一个循环,不能因为一个城管就结束掉整个生活的循环呀,这就是只结束当前这层循环。

a = 1
while a <= 10:
a+= 1if a == 5:continue
if a == 8:break
printa

布尔代数化简 用python 布尔函数python_python布尔类型运算_16

另外,while循环也可以和 if 一样使用 else。

a =0while a<= 5:printa
a+=1
else:print '条件为假了'

布尔代数化简 用python 布尔函数python_while循环_17

不过一般很少这样用了,因为while循环条件为假是会自动跳出循环,此时会自动执行下面的同级代码,所以直接写在while的下面的同级处就可以了。

但是,这样写能够提供代码的可读性,具体如何选择看个人需要。

剩下的 for 循环会在后面另起一篇说明。

关于布尔值和流程控制暂时就是这些,后续有需求的话,我会进行补充说明。