Python学习入门基础教程(learning Python)--3.3.3 Python逻辑关系表达式
在if分支判断语句里的条件判断语句不一定就是一个表达式,可以是多个(布尔)表达式的组合关系运算,这里如何使用更多的关系表达式构建出一个比较复杂的条件判断呢?这里需要再了解一下逻辑运算的基础知识。逻辑关系运算有以下几种运算符.
下面是逻辑与实例,通过例子我们了解一下and、or等逻辑运算操作机制。
def if_check():
global x
x = 79
print(" in if_check x = ", x)
if x >= 60 and x < 70:
print(" good")
if x >= 70 and x < 80:
print(" better")
if x >= 80 and x < 90:
print(" best")
if x >= 90 and x < 100:
print(" Excellent")
if x < 60:
print(" You need improve") def main():
global x
print(" in main x = ", x)
if_check() x = 12
main()
Python程序运行结果如下所示。
由于x = 79所以只有if x >= 70 and x < 80:的condition满足,故打印better,这里我们可以看出逻辑and运算符是要求and前后的布尔值都是真才能判定condition为真。
     我们在看看or或逻辑运算符的实例,or要求or两边的布尔值有一个为真即判定if的conditon为真,如果两边都是假,那么if的条件判断值为假。思考一下如果我们把上边的程序里的所有and都改成or,会打印几条?
def if_check():
global x
x = 79
print(" in if_check x = ", x)
if x >= 60 or x < 70:
print(" good")
if x >= 70 or x < 80:
print(" better")
if x >= 80 or x < 90:
print(" best")
if x >= 90 or x < 100:
print(" Excellent")
if x < 60:
print(" You need improve") def main():
global x
print(" in main x = ", x)
if_check() x = 12
main()
请自己分析一下程序的运行结果。
good和better被打印出来可以理解(79 >= 60, 79 > = 70都为真),但为何best和Excellent也被打印出来了呢?
 当x = 79时,x >= 80为假但x < 90确实真,两者做逻辑或运算其综合表达式的值为真。同理,if x >= 90 or x < 100:里有79 < 100为真,故if的条件判断语句(x >= 90 or x < 100)为真。
最后需要说明一点的是,在if里and和or可以不止一个。
if (x > 0 or x < 100) and (y > 0 or y < 100):
z = x * y
——————————————————————————————————
Python学习入门基础教程(learning Python)--3.3.3 Python逻辑关系表达式的更多相关文章
- Python学习入门基础教程(learning Python)--5.6 Python读文件操作高级
		
前文5.2节和5.4节分别就Python下读文件操作做了基础性讲述和提升性介绍,但是仍有些问题,比如在5.4节里涉及到一个多次读文件的问题,实际上我们还没有完全阐述完毕,下面这个图片的问题在哪呢? 问 ...
 - Python学习入门基础教程(learning Python)--3.3.2 Python的关系运算
		
如果if的condition不用布尔表达式来做条件判断而采用关系表达式,实际上关系表达式运算的结果要么是True要么是False.下面我们先了解一些有关关系运算符的基础知识,如下表所示. 做个小程序测 ...
 - Python学习入门基础教程(learning Python)--2.3.3Python函数型参详解
		
本节讨论Python下函数型参的预设值问题. Python在设计函数时,可以给型参预设缺省值,当用户调用函数时可以不输入实参.如果用户不想使用缺省预设值则需要给型参一一赋值,可以给某些型参赋值或不按型 ...
 - Python学习入门基础教程(learning Python)--6.3 Python的list切片高级
		
上节"6.2 Python的list访问索引和切片"主要学习了Python下的List的访问技术:索引和切片的基础知识,这节将就List的索引index和切片Slice知识点做进一 ...
 - Python学习入门基础教程(learning Python)--5.3 Python写文件基础
		
前边我们学习了一下Python下如何读取一个文件的基本操作,学会了read和readline两个函数,本节我们学习一下Python下写文件的基本操作方法. 这里仍然是举例来说明如何写文件.例子的功能是 ...
 - Python学习入门基础教程(learning Python)--5.1 Python下文件处理基本过程
		
Python下的文件读写操作过程和其他高级语言如C语言的操作过程基本一致,都要经历以下几个基本过程. 1. 打开文件 首先是要打开文件,打开文件的主要目的是为了建立程序和文件之间的联系.按程序访问文件 ...
 - Python学习入门基础教程(learning Python)--5.2 Python读文件基础
		
上节简单的说明了一下Pyhon下的文件读写基本流程,从本节开始,我们做几个小例子来具体展示一下Python下的文件操作,本节主要是详细讲述Python的文件读操作. 下面举一个例子,例子的功能是读取当 ...
 - Python学习入门基础教程(learning Python)--5 Python文件处理
		
本节主要讨论Python下的文件操作技术. 首先,要明白为何要学习或者说关系文件操作这件事?其实道理很简单,Python程序运行时,数据是存放在RAM里的,当Python程序运行结束后数据从RAM被清 ...
 - Python学习入门基础教程(learning Python)--8.3 字典常用的方法函数介绍
		
本节的主要讨论内容是有关dict字典的一些常用的方法函数的使用和范例展示. 1. clear清除字典数据 语法结构如下: dict_obj.clear() 示例代码如下: dict1 = {'web' ...
 
随机推荐
- H2内存数据库 支持存储到文件
			
 准备工作 1.下载JDK(本人下载的版本号为JDK1.7).环境变量设置JAVA_HOME.设置PATH(%JAVA_HOME%\bin%). 2.下载并解压:h2-2014-07-13.zip ...
 - Spring的事件处理
			
Spring对事件有一些支持,因为项目须要,所以近期小小研究了下究竟这个怎么能够方便的用在实际项目其中来. 说起事件这个东西,事实上就是借鉴的那个观察者模式.这里面涉及到事件源.事件监听者.事件公布者 ...
 - Opencv实现图像的灰度处理,二值化,阀值选择
			
前几天接触了图像的处理,发现用OPencv处理确实比較方便.毕竟是非常多东西都封装好的.可是要研究里面的东西,还是比較麻烦的,首先,你得知道图片处理的一些知识,比方腐蚀,膨胀,仿射,透射等,还有非常多 ...
 - clear、REFRESH、free区别
			
clear可以清楚一个工作区或变量.但是如果该内表是带表头的,清空内表时需要在该内表后加[].例如:clear gt_tab[]. free可以清空带表头的内表但是不会清空这个带表头内表的表头,但是也 ...
 - java中文排序问题(转)
			
在Java中,对一个数组或列表(在本文中统称为集合)中的元素排序,是一个很经常的事情.好在Sun公司在Java库中实现了大部分功能.如果集合中的元素实现了Comparable接口,调用以下的静态(st ...
 - android打包apk时混淆遇到的问题
			
android打包apk的时候一般会选择混淆,而在eclipse中常使用的是proguard来混淆.有很多时候引用了第三方包的时候会导致打包不成功,或者打包成功不能运行的情况. 首先看看正常的prog ...
 - 每次调用fork()函数之后,父线程和创建出的子线程都是从fork()后开始执行
			
Linux下多少个"-"将被打印: 1 2 3 4 5 6 7 8 int main(void){ int i; for(i=0;i<4;i++){ fork() ...
 - 设置 Linux 的 LD_LIBRARY_PATH 变量
			
源地址:http://www.cnblogs.com/trying/archive/2013/06/07/3123577.html 我们在ubuntu图形界面下用eclipse写了一个动态库,到cen ...
 - RotateDisp – 一键旋转显示画面 - 小众软件
			
RotateDisp – 一键旋转显示画面 - 小众软件 RotateDisp – 一键旋转显示画面
 - oracle查询语句中case when的使用
			
case when语句语法如下: case when 表达式 then valueA else valueB end; 具体使用如下: select (case when a.colum ...