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。第二和第三方法相差不多。
Python 迭代dict 效率的更多相关文章
- Python 迭代dict的value
		迭代dict的value 1:values() 2:itervalues() 3:for key in Di: print (Di[key]) 我们已经了解了dict对象本身就是可迭代对象, ... 
- Python迭代dict的value
		我们已经了解了dict对象本身就是可迭代对象,用 for 循环直接迭代 dict,可以每次拿到dict的一个key. 如果我们希望迭代 dict 对象的value,应该怎么做? dict 对象有一个 ... 
- python迭代和切片
		from collections import Iterable #切片************************ # #取一个list或tuple的部分元素是非常常见的操作 ,Python提供 ... 
- 完全理解 Python 迭代对象、迭代器、生成器(转)
		完全理解 Python 迭代对象.迭代器.生成器 本文源自RQ作者的一篇博文,原文是Iterables vs. Iterators vs. Generators » nvie.com,俺写的这篇文章是 ... 
- 完全理解 Python 迭代对象、迭代器、生成器
		完全理解 Python 迭代对象.迭代器.生成器 2017/05/29 · 基础知识 · 9 评论 · 可迭代对象, 生成器, 迭代器 分享到: 原文出处: liuzhijun 本文源自RQ作者 ... 
- 迭代dict的value
		我们已经了解了dict对象本身就是可迭代对象,用 for 循环直接迭代 dict,可以每次拿到dict的一个key. 如果我们希望迭代 dict 对象的value,应该怎么做? dict 对象有一个 ... 
- Python迭代(入门8)
		转载请标明出处: http://www.cnblogs.com/why168888/p/6407980.html 本文出自:[Edwin博客园] Python迭代 1. 什么是迭代 注意: 集合是指包 ... 
- python 迭代 及列表生成式
		什么是迭代 在Python中,如果给定一个list或tuple,我们可以通过for循环来遍历这个list或tuple,这种遍历我们成为迭代(Iteration). 在Python中,迭代是通过 for ... 
- Python的dict字典结构操作方法学习笔记
		Python的dict字典结构操作方法学习笔记 这篇文章主要介绍了Python的dict字典结构操作方法学习笔记本,字典的操作是Python入门学习中的基础知识,需要的朋友可以参考下 一.字典的基本方 ... 
随机推荐
- petapoco IsNew
			// Check if a poco represents a new record public bool IsNew(string primaryKeyName, object poco) { v ... 
- Linux下ejabberd安装配置
			1.下载Ejabberd安装包 wget http://www.process-one.net/downloads/ejabberd/2.1.13/ejabberd-2.1.13-linux-x86_ ... 
- windows与OSX双操的时区-黑苹果之路
			问题由来已久,原因好像是windows识别时间的方式跟OSX不一样,方法如下: 1,改苹果系统时区为冰岛 2,改window系统的注册表 在管理员cmd下运行 Reg add HKLM\SYSTEM\ ... 
- 关于oracle中to_char和to_date的用法
			一.24小时的形式显示出来要用HH24 select to_char(sysdate,'yyyy-MM-dd HH24:mi:ss') from dual; select to_date('200 ... 
- HTML实体字符转化为HTML标签
			html_entity_decode方法 参数 描述 string 必需.规定要解码的字符串. flags 可选.规定如何处理引号以及使用哪种文档类型. 可用的引号类型: ENT_COMPAT - 默 ... 
- 深入学习微框架:Spring Boot(转)
			转:http://www.infoq.com/cn/articles/microframeworks1-spring-boot/ 相关参考: https://spring.io/guides/gs/s ... 
- Linux课程实践一:Linux基础实践(基础操作)
			一.软件源维护 1. 基本操作 (1)查看源列表 sudo vim /etc/apt/sources.list deb:二进制软件安装包 deb-src:源码包 (2)备份软件源列表 sudo cp ... 
- 循序渐进Python3(七) --1-- 面向对象
			Python 面向对象 什么是面向对象编程? 面向对象编程是一种程序设计范式 对现实世界建立对象模型 把程序看作不同对象的相互调用 Python从设计之初就已经是一门面向对象的语言,正因为如此,在Py ... 
- Django concept
			1. MVC in Django http://stackoverflow.com/questions/6621653/django-vs-model-view-controller https:// ... 
- 设置input 内容居中显示 .
			text-align:center 水平居中显示 <style type="text/css"> input.text{text-align:center;paddi ... 
