这两个都是一样的结果呢
z = {'a': 1, 'b': 2, 'c':3} 'a' in z z.has_key('a')
楼上说得都够详细了,我就贴段代码吧:
#src/Python-2.6.8/Objects/dictobject.c static PyObject * dict_has_key(register PyDictObject *mp, PyObject *key) { if (PyErr_WarnPy3k("dict.has_key() not supported in 3.x; " "use the in operator", 1) < 0) return NULL; return dict_contains(mp, key); }
从运算角度来说,使用in更快
> python2 -mtimeit -s'd=dict.fromkeys(range(99))' '12 in d'
10000000 loops, best of 3: 0.0374 usec per loop
> python2 -mtimeit -s'd=dict.fromkeys(range(99))' 'd.has_key(12)'
10000000 loops, best of 3: 0.0719 usec per loop
这也是为什么使用in更加好的原因
http://www.chenxm.cc/post/672...
2 回答4.3k 阅读✓ 已解决
2 回答872 阅读✓ 已解决
1 回答4.1k 阅读✓ 已解决
3 回答872 阅读✓ 已解决
2 回答2.2k 阅读✓ 已解决
4 回答2.6k 阅读
3 回答915 阅读✓ 已解决
官方文档推荐用 key in dict 的语法,因为它更短更通俗易懂。has_key是老旧遗留的api,为了支持2.2之前的代码留下的。Python3已经删除了该函数。