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')
同时获取元素的索引和元素本身。