Python列表解析器和生成器

filelist2 = [i for i in filelist1 if i.endswith('.log')]
 l1 = ['x','y','z']
 l2 = [1,2,3]
 l3 = [(i,j) for i in l1 for j in l2]
 print l3
[('x', 1), ('x', 2), ('x', 3), ('y', 1), ('y', 2), ('y', 3), ('z', 1), ('z', 2), ('z', 3)]

列表解析直接返回一个新列表。
生成器和列表解析的关系类似于range 和 xrange 的关

生成器表达式并不真正创建数字列表,二十返回一个生成器,此对象在每次计算一个条目后把这个条目产生(yield)出来。将列表解析器的中括号换成小括号即可。

序列过长,并且每次只需要获取一个元素时,尽量使用生成器。

for i in ( i**2 for i in range(1,11)):print i/2
0
2
4
8
12
18
24
32
40
50

产生偏移和元素:

enumerate() 函数

s = 'hello world'

In [288]: e = enumerate(s)

In [289]: e.next()
Out[289]: (0, 'h')

In [290]: e.next()
Out[290]: (1, 'e')

In [291]: e.next()
Out[291]: (2, 'l')

同时获取元素的索引和元素本身。

原文地址:https://www.cnblogs.com/Beny-Bruce/p/5022296.html