代码中经常会有变量是否为None的判断,有三种主要的写法:
第一种是 if x is None ;第二种是 if not x: ;第三种是 if not x is None (这句这样理解更清晰 if not (x is None) ) 。
如果你觉得这样写没啥区别,那么你可就要小心了,这里面有一个坑。先来看一下代码:
当然在学习Python的道路上肯定会困难,没有好的学习资料,怎么去学习呢?
私信小编01即可获取大量Python学习资料
>>> x=1>>> not xFalse>>> x=[1]>>> not xFalse>>> x=0>>> not xTrue>>> x=[0] >>> not xFalse复制代码
在python中 None, False, 空字符串"", 0, 空列表[], 空字典{}, 空元组()都相当于False ,即:
not None==not False==not ''==not 0==not []==not {}==not ()复制代码
因此在使用列表的时候,如果你想区分 x==[] 和 x==None 两种情况的话, 此时 if not x: 将会出现问题:
#Python学习交流群:531509025>>> x=[]>>> y=None>>> >>> x is NoneFalse>>> y is NoneTrue>>> >>> >>> not xTrue>>> not yTrue>>> >>> >>> not x is None>>> True>>> not y is NoneFalse>>>复制代码
也许你是想判断x是否为None,但是却把 x==[] 的情况也判断进来了,此种情况下将无法区分。
对于习惯于使用if not x这种写法的pythoner,必须清楚x等于None, False, 空字符串"", 0, 空列表[], 空字典{}, 空元组()时对你的判断没有影响才行。
而对于 if x is not None 和 if not x is None 写法,很明显前者更清晰,而后者有可能使读者误解为 if (not x) is None ,因此推荐前者,同时这也是谷歌推荐的二手风格
if x is not None 是最好的写法,清晰,不会出现错误,以后坚持使用这种写法。
使用 if not x 这种写法的前提是:必须清楚x等于None, False, 空字符串"", 0, 空列表[], 空字典{}, 空元组()时对你的判断没有影响才行。