Python 迭代dict 效率

迭代dict也要讲求效率,不然就要走进性能陷阱

以下三种迭代方式:keys,iterkeys, hashkey

import timeit

DICT_SIZE = 100 * 100000

testDict = dict()
for i in xrange(DICT_SIZE):
    testDict[i] = i

assert len(testDict) == DICT_SIZE

def test1():
    for _ in testDict.keys():
        pass

def test2():
    for _ in testDict.iterkeys():
        pass

def test3():
    for _ in testDict:
        pass

print timeit.timeit("test1()", setup="from __main__ import test1", number=2000)
print timeit.timeit("test2()", setup="from __main__ import test2", number=2000)
print timeit.timeit("test3()", setup="from __main__ import test3", number=2000)

结果:

4198.55953097
1695.41651607
1896.270154

keys()会生成一个list,耗内存又耗时间;iterkeys是迭代key,不会生成list。第二和第三方法相差不多。

时间: 2024-10-02 08:56:37

Python 迭代dict 效率的相关文章

Python迭代dict的value转载http://www.imooc.com/learn/177

我们已经了解了dict对象本身就是可迭代对象,用 for 循环直接迭代 dict,可以每次拿到dict的一个key. 如果我们希望迭代 dict 对象的value,应该怎么做? dict 对象有一个 values() 方法,这个方法把dict转换成一个包含所有value的list,这样,我们迭代的就是 dict的每一个 value: d = { 'Adam': 95, 'Lisa': 85, 'Bart': 59 } print d.values() # [85, 95, 59] for v i

Python 迭代dict的value

迭代dict的value 1:values() 2:itervalues()  3:for key in Di:     print (Di[key]) 我们已经了解了dict对象本身就是可迭代对象,用 for 循环直接迭代 dict,可以每次拿到dict的一个key. 如果我们希望迭代 dict 对象的value,应该怎么做? dict 对象有一个 values() 方法,这个方法把dict转换成一个包含所有value的list,这样,我们迭代的就是 dict的每一个 value: d = {

python入门七(迭代)【9-3 python之迭代dict的value和key】

9-3 python之迭代dict的value和key 我们了解了如何迭代 dict 的key和value,那么,在一个 for 循环中,能否同时迭代 key和value?答案是肯定的. 首先,我们看看 dict 对象的 items() 方法返回的值: >>> d = { 'Adam': 95, 'Lisa': 85, 'Bart': 59 } >>> print d.items() [('Lisa', 85), ('Adam', 95), ('Bart', 59)]

Python之dict的认识

Python入门—— dict flyingSquirrel                                 微信号                                 squirrel_jie 功能介绍                                 生活亦是灵感.记录点滴生活,珍藏美好回忆. 什么是dict 我们已经知道,list 和 tuple 可以用来表示顺序集合,例如,班里同学的名字: ['Adam', 'Lisa', 'Bart'] 或者考

Python中dict的特点、更新dict、遍历dict

dict的第一个特点是查找速度快,无论dict有10个元素还是10万个元素,查找速度都一样.而list的查找速度随着元素增加而逐渐下降. 不过dict的查找速度快不是没有代价的,dict的缺点是占用内存大,还会浪费很多内容,list正好相反,占用内存小,但是查找速度慢. 由于dict是按 key 查找,所以,在一个dict中,key不能重复. dict的第二个特点就是存储的key-value序对是没有顺序的!这和list不一样: d = { 'Adam': 95, 'Lisa': 85, 'Ba

Python中dict详解

yangyzh Python中dict详解 python3.0以上,print函数应为print(),不存在dict.iteritems()这个函数. 在python中写中文注释会报错,这时只要在头部加上# coding=gbk即可 #字典的添加.删除.修改操作dict = {"a" : "apple", "b" : "banana", "g" : "grape", "o&qu

菜鸟学python之dict

存储位置=hash(键) 在搜索时,首先对键进行hash运算,把求得的值当做"键-值对"的存储位置,在结构中按照此位置取"键-值对"进行比较,若键相等,则表示搜索成功.在存储"键-值对"的时候,依照相同的hash函数计算存储位置,并按此位置存放,这种方法就叫做哈希方法,也叫做散列方法.在哈希方法中使用的转换函数hash被称作哈希函数(或者散列函数).按照此中算法构造出来的表叫做哈希表(或者散列表). 哈希函数建立了从"键-值对"

python将dict中的unicode打印成中文

python将dict中的unicode打印成中文 import json a = {u'content': {u'address_detail': {u'province': u'\u5409\u6797\u7701', u'city': u'\u957f\u6625\u5e02', u'street_number': u'', u'district': u'', u'street': u'', u'city_code': 53}, u'point': {u'y': u'43.89833761

Python中将dict转换为kwargs

Python中将dict转换为kwargs 我们都知道kwargs是变长kv参数,能否将dict转换成kwargs. 在python调用函数的时候func(**{'type'='event'}),可以将dict转化为kwargs. 参考 Converting Python dict to kwargs?