Python部落(www.freelycode.com)组织翻译, 禁止转载
介绍
下面的排序都是非常常见的日常使用场景,我们要用Pythonic的方式来使用它们!
1. 循环遍历数字的范围
for i in [0,1,2,3,4,5]:
print i**2
更好的方式 (看上去更好):
for i in range(6):
print i**2
在这次循环中发生了什么?
range 在内存中创建一个列表然后for循环遍历这个列表。
两种方式都是在内存中创建6个整数然后迭代每个数字,将它们二次方然后答应出来。所以上面两个循环是使用了完全相同的方式做了相同的事情!
Pythonic方式:使用xrange()
#Python 2.x
for i in xrange(6):
print i**2
#Python 3.x
for i in range(6):
print i**2
什么是xrange?
Xrange是一个lazy方式求值的序列对象。
xrange 通过范围(列表)创建一个迭代器并且每次使用只会产生一个数字,因此比上面的方法消耗更少的内存。
2. 循环遍历一个集合
colours = ['red', 'green', 'blue', 'yellow']
for i in range(len(colours)):
print colours[i]
Pythonic方式
for colour in colours:
print colour
3.遍历一个集合和它的索引
for i in range(len(colours)):
print i, '-->', colours[i]
Pythonic 方式: 使用enumerate()
for i, colour in enumerate(colours):
print i, '-->', colour
4. 反向遍历
for i in range(len(colours), -1, -1, -1):
print colours[i]
Pythonic 方式: 使用reversed()
for colour in reversed(colours):
print colour
5.有序遍历
Pythonic 方式: 使用sorted()
for colour in sorted(colours):
print colour
有序反向遍历
只需要在sorted方法的参数中添加reverse=True。
Pythonic 方式
for colour in sorted(colours, reverse=True):
print colour
6. 遍历两个集合
names = ['a', 'b', 'c']
colours = ['red', 'green', 'blue', 'yellow']
n = min(len(colours), len(names))
for i in range(n):
print names[i], '-->', colours[i]
更好的方法
for name, colour in zip(names, colours):
print name, '-->', colour
zip 在内存中创建由元组组成的第三个列表, 其中每一个元素都是带有指向原始数据指针的独立对象。换句话说,它需要比原来两个列表的总和还要使用更多的内存。
最重要的是”这本来就不是比例决定的”。Pythonic 方式: 使用 izip()
from itertools import izip
for name, colour in izip(names, colours):
print name, '-->', colour
对于较小的列表, zip是比较快的,但是如果你的列表有数百万的数据,那么最要使用izip, 应为只有izip 会在需要的时候优先使用迭代器。
英文原文: http://www.codeproject.com/Tips/829060/Python-Code-Optimizations-Part-One
译者: terry