python字典结构get()方法的陷阱

字典是python中常用的数据结构,get()方法可用来判断字典中是否存在对应的key,但是当该key的对应value为0时,使用该方法来判断key是否存在容易出错。
get()方法使用如下:

mydict.get(1)
#假如字典中存在key为1的键值对,那么返回1对应的value值,如果不存在则返回None
mydict.get(1, -1)
#假如字典中存在key为1的键值对,那么返回1对应的value值,如果不存在则返回-1

我们时常需要使用get()方法的返回值来判断字典中是否存在这个key值,如下:

mydict = {1:0, 2:3}
if mydict.get(1):
    print "key = 1 exists"
else:
    print "key = 1 not exists"
if mydict.get(2):
    print "key = 2 exists"
else:
    print "key = 2 not exists"

执行的结果如下:
这里写图片描述
可见,该程序正确判断了key = 2的存在,却错误判断key = 1不存在。
原因是:mydict[1] = 0,所以,mydict.get(1)的返回值为0,而0在条件中代表的是False,所以结果错误
该错误的原因是很简单的,这也没有涉及语言的原则性错误,但是它确实很容易导致我们产生错误,所以在判断字典元素是否存在时,更好的代码应该是这样的:

mydict = {1:0, 2:3}
if mydict.get(1) != None:
    print "key = 1 exists"
else:
    print "key = 1 not exists"
if mydict.get(2) != None:
    print "key = 2 exists"
else:
    print "key = 2 not exists"

执行结果为:
这里写图片描述
结果正确,当然如果你定义不存在的时候返回的值不是None,那就要把None换成那个值了。但是这还是会有一点隐患,假如你定义不存在时返回值ret,如果该值在字典中对应的value就是ret那就又出错了,所以挑选这个值的时候应该根据使用环境挑选。

你可能感兴趣的:(python)