前言:对于我这种追求极致的人来说,效率很重要。
前面看到网上关于python循环的测评,到自己在项目中的应用,发现,并不是这么回事。所以,写下次博文,一次性了解这个问题。
语言版本:python3.6
平台:mac10.12.6
IDE:pycharm community 2018.2
关于循环的介绍:
1. for循环
我们最开始使用的循环。for循环的对象是可迭代对象。这里不详述。
2. 列表解析式
与之类似,字典解析式,集合解析式等。
3. map循环
与之类似有reduce,filter。这里不详述。
最终测试结果:
map比列表解析式快一点点,
列表解析式,大概比普通for循环快1.5倍。
符合预期。(擦了一把汗!)
ps:有同学测试,说map速度远远大与列表推导式(大概快10000倍),这是因为他返回的是生成器对象,并没有计算出结果,所以这个不算。
以上测试,只是反映实际情况一种。并不能说这个是公理。仅仅给大家提供参考。博主不才。
测试开始:
importtime
i= list(range(1000000)) # 生成测试序列
首先测试将数字转换成字符串:
i = list(range(1000000))
t = time.time()
lt_1 = []
for e