if语句实际上是:if True: …执行后面的语句
python 中的 if 有下面几种常见用法:
if … else…
if …elif…else…
if not …
if … not …
实际上,还可以用用下面这种方式,使代码更精简:
赋值也是可以的:
elif 是多条件判断语句,比如:
当然,当条件很多时,可以有多个elif,比如上面这个简单的例子可以再增加几个条件
i在讲 if not 之前,得先弄清楚 not 在python中的意思:
not 是一个逻辑判断词
当 not 与变量连用的时候:
所以,在python中,None, False, 空字符串 ‘’ , 0, 空列表[], 空字典{}, 空元组() 都相当于False。
要注意的是,虽然”0“是 False,但是 ”[0]" 是True ,因为只有空列表为False,字典也是如此,另外有空格的字符串 ’ ’ 也不算空字符串。
仔细的同学可能看到上面元组(0)并不是True,那是因为在写元组tupple时,如果只有一个元素,需要在元素后面加上逗号,比如:(0,),指定为元组类型,如果不加逗号,python会把它当成整型,整数 0 为False,所以(0)也为False。
弄清楚not之后,加上 if 就很简单了,如果if not 后面的语句是False,则执行冒号后面的语句,否则执行else(如果有else的话)。
-
这种情况一般 not 与 is 连用,is not 直接按字面理解即可。
理解为 if x (is not) None,而不是if x is (not None)。
补充:
在实际写代码的时候,经常遇到要判断None的情况,可能会遇见下面这些写法:
if x is None:…#最好使用这种写法
if not x:…
if not x is None: …
而在判断None的过程,常常伴随着 [] 的判断,这时我们使用if not x是有问题的:
因为上面讲过,not是逻辑判断,而列表、空字典等的逻辑和None是一样的,都是False,if not 是没办法区分的,输出的都是True。
所以要确定变量=[]时对if not 的判断没有影响,否则会报错。
使用 if not x is None也是有问题的,这种写法容易误解为if (not x) is None,而实际上应该理解为 not (a is None)
a is None 返回False ,所以not(False)返回True,而实际上[] 并不是None,应该返回False
所以最好直接使用if x is None,简介明了。
a is b比较的a 和 b的id,只有a,b的id相同才会输出True:
上面if … not …中的 is not其实是一样的道理
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)