列表解析基本语法:
[expr for iter_var in iterable]这个语句的核心是for循环,它迭代iterable对象的所有条目。列表解析可以有效的替代lambda。
>>> map(lambda x: x**2, range(6)) [0, 1, 4, 9, 16, 25] >>> [x ** 2 for x in range(6)] [0, 1, 4, 9, 16, 25]使运行效率更高。
结合if语句,
[expr for iter_var in iterable if cond_expr] >>> s = [1, 2, 3, 5, 6, 8, 7, 31, 99] >>> filter(lambda x: x%2, s) [1, 3, 5, 7, 31, 99]完全可以用列表解析替代
>>> [i for i in s if i%2] [1, 3, 5, 7, 31, 99]矩阵样例
>>> [(x + 1, y + 1) for x in range(3) for y in range(3)] [(1, 1), (1, 2), (1, 3), (2, 1), (2, 2), (2, 3), (3, 1), (3, 2), (3, 3)] >>> [(x, y) for x in range(3) for y in range(3)] [(0, 0), (0, 1), (0, 2), (1, 0), (1, 1), (1, 2), (2, 0), (2, 1), (2, 2)]磁盘文件样例
f = open('xxx.txt', 'r') len([word for line in f for word in line.split()])#循环遍历所有行和所有单词计算单词个数
f.seek(0) sum([len(word) for line in f for word in line.split()])回到文件开头,计算单词所有单词长度。
列表解析实现99乘法表
print('\n'.join([''.join(['%s*%s=%-2s '%(y,x,x*y)for y in range(1,x+1)])for x in range(1,10)]))