02.16 列表推导式

列表推导式

循环可以用来生成列表:

1values = [10, 21, 4, 7, 12]
2squares = []
3for x in values:
4    squares.append(x**2)
5print squares
[100, 441, 16, 49, 144]

列表推导式可以使用更简单的方法来创建这个列表:

1values = [10, 21, 4, 7, 12]
2squares = [x**2 for x in values]
3print squares
[100, 441, 16, 49, 144]

还可以在列表推导式中加入条件进行筛选。

例如在上面的例子中,假如只想保留列表中不大于10的数的平方:

1values = [10, 21, 4, 7, 12]
2squares = [x**2 for x in values if x <= 10]
3print squares
[100, 16, 49]

也可以使用推导式生成集合和字典:

1square_set = {x**2 for x in values if x <= 10}
2print(square_set)
3square_dict = {x: x**2 for x in values if x <= 10}
4print(square_dict)
set([16, 49, 100])
{10: 100, 4: 16, 7: 49}

再如,计算上面例子中生成的列表中所有元素的和:

1total = sum([x**2 for x in values if x <= 10])
2print(total)
165

但是,Python会生成这个列表,然后在将它放到垃圾回收机制中(因为没有变量指向它),这毫无疑问是种浪费。

为了解决这种问题,与xrange()类似,Python使用产生式表达式来解决这个问题:

1total = sum(x**2 for x in values if x <= 10)
2print(total)
165

与上面相比,只是去掉了括号,但这里并不会一次性的生成这个列表。

比较一下两者的用时:

1x = range(1000000)
1%timeit total = sum([i**2 for i in x])
1 loops, best of 3: 3.86 s per loop
1%timeit total = sum(i**2 for i in x)
1 loops, best of 3: 2.58 s per loop